写了如下一段代码,代码理解在其中,望牛人解答理解是否正确。
// m声明完后,m存储了m数组第一个字符的地址,但m并不是指针
char m[] = "abcdef";
// 才是指针,该指针的地址为m的值
char *x = m;
// 这种方式是将上面两步合二为一,则n就代表了指向数组的第一个未知的指针
char *n = "abcdef";
// 数组m的长度
printf("%d\n", sizeof(m));
// 指针x的长度
printf("%d\n", sizeof(x));
// 指针n的长度
printf("%d\n", sizeof(n));
char m[]
和 char *n
是有本质区别的,见我前天的回答:http://.net/q/1010000002591185
我也是新手,我觉得你的理解是对的。我也是这么理解的。
sizeof(m)应该是7.
sizeof(x)这个就是一个指针变量的长度,具体好像看编译器
sizeof(n)也一样
其实在内存上没什么差别,但编译器知道,m是字符串数组,x是字符指针。
于是在编译sizeof(m)
的时候,~~编译器生成指令去根据当前内存管理方式找到申明的数组长度~~编译器生成指令返回数组长度,在编译sizeof(x)
的时候,编译器生成指令直接返回指针大小。
中间更正一下,sizeof的值就是在编译时确定的
其实像你例子这样得情况下,编译器根本不用生成指令去找那些长度,因为编译时数组长度已经确定,所以m的长度7
就在指令里作为操作数了。一般free
malloc
出来的空间才会去找。
总之,,编译器已经看透了一切。。