首先,定义一个数组:int arrA[10];
然后,分别打印其首元素地址和整个数组的地址:printf("数组首元素地址= %d, 数组第一个元素的地址= %d\n", arrA, &arrA");

打印结果是:

可以断定这两者在数值上是相等的。
那么问题来了:
1、arrA+1 和 &arrA + 1相等吗?
2、sizeof(arrA) 和 sizeof(&arrA)相等吗?

输出结果:

结论:
对于问题1:
1、arrA和&arrA在逻辑上的起点是一样的,但是两者实际上的“步长”不一样。arrA的“步长”是一个(int)元素,&arrA的“步长”是整个数组的长度(10个(int)元素)。
对于问题2:
2、sizeof求被求对象占字节数,它关心被求对象的数据类型和个数。arrA的数据类型为int型,个数为10,因此字节数为4*10=40。&arrA的数据类型为int *型,个数为1,因此字节数为4*1 = 4。
本文深入探讨了数组和指向数组的指针之间的区别,通过对比arrA和&arrA的特性,解释了它们在内存地址、步长及sizeof运算符上的不同表现。

被折叠的 条评论
为什么被折叠?



