我在用C语言处理字节数组时遇到一个数组与指针的问题。
当我使用指针时(如下)编译通过执行出错。
typedef unsigned char byte;
int main(){
printf("The program begins\n");
byte *head = {0xFE,0xFF};
printf("demo -> %.2x",head[1]);
return 0;
}
编译和执行结果错误
gcc -g -c demo.c
demo.c:13:19: warning: incompatible integer to pointer conversion initializing 'byte *' (aka 'unsigned char *') with an expression of type 'int' [-Wint-conversion]
byte *head = {0xFE,0xFF};
^~~~
demo.c:13:24: warning: excess elements in scalar initializer
byte *head = {0xFE,0xFF};
^~~~
2 warnings generated.
gcc -g -o demo demo.o tcp_handle.o
# xxx @ shuMacBook-Pro in ~/personal_data/leand/dome/C_dome/tcp_handle [23:47:47]
$ ./demo
The program begins
[1] 74322 segmentation fault ./demo
而当我使用数组时(如下),却能正常执行
typedef unsigned char byte;
int main(){
printf("The program begins\n");
byte head[] = {0xFE,0xFF};
printf("demo -> %.2x",head[1]);
return 0;
}
结果
gcc -g -c demo.c
gcc -g -o demo demo.o tcp_handle.o
# xxx @ shuMacBook-Pro in ~/personal_data/leand/dome/C_dome/tcp_handle [23:56:19]
$ ./demo
The program begins
demo -> ff%
通过编译时的提示,我大概猜测使用指针时,把十六进制的元素当作整型存储了,并把首地址赋值给力head。但是为什么数组却能将内部的元素当作定义时的类型存储呢?我对C语言指针和数组这方面的知识比较欠缺。希望能被点醒。或推荐一些资料(看过一些帖子,没有遇到相似情况的)。