一、一维数组
我们借助sizeof帮助我们理解:
运行结果如下:
二、二维数组
同样借助sizeof来理解:
运行结果如下:
三、字符型数组
1 借助sizeof来理解:
类似的:
注意:a、b数组有一些差别,造成这种差别的原因是b数组是字符串赋值,此时,字符串结尾的‘\0’同样赋给了数组b,所以数组b比数组a多一个元素;
2 借助strlen来理解:
注意:1 从运行结果中我们看到了一些随机值(19),这些随机值为什么会产生呢?这是因为strlen测得是字符串的长度,以'\0'为结束标志;而a数组没有‘\0’元素。
2 从运行结果中我们还看到了一些随机值(14、29),&a取的是a数组的地址,而&a+1是跳过a数组所有元素后的内存单元的地址;同意,b数组也是如此。
四、总结
数组名单独放在sizeof内,代表整个数组;
&数组名代表数组的地址;
数组名+1 中数组名代表首元素地址