1.数组名是指针么?建立一个二维数组,用sizeof进行验证。
#include
#include
using namespace std;
int main()
{
char a[10][10];
/*&a,a,a[0],&a[0],&a[0][0]那些是指针,那些不是指针,用sizeof进行验证*/
printf("sizeof(&a) = %d\r\n",sizeof(&a));
printf("sizeof(a) = %d\r\n",sizeof(a));
printf("sizeof(a[0]) = %d\r\n",sizeof(a[0]));
printf("sizeof(&a[0][0]) = %d\r\n",sizeof(&a[0][0]));
system("pause");
}
运行结果如下:
我们知道指针大小应该是4个字节,所以可只,&a,&a[0],&a[0][0]是指针,a,a[0]不是指针。
我的理解是&a指向的是二维数组a,即存放的是a的地址,&a[0]指向的是一维数组,&a[0][0]很好理解,直接指向一个char。
a,a[0]都是数组名。
由此可得结论:数组名不是指针,&取到的是指针。
2.现在以指针的形式打印他们的值,观察大小。
结果如下:
很有趣的结果,他们竟然都相等,不过只是值相等,以指针的形式打印结果,可是上面我们已经等到结论a,a[0]并不是指针,其实这里a和a[0]已进行了隐式转化,虽然大小一样但其实他们各自的指向是不同的,所以其实意义并不同。
3.现在验证经过隐式转换后他们有什么不同。
结果如下:
可知 &a + 1 - &a = 0xe8 - 0x84 = 100 等于二维数组的大小,验证了&a指向的是二维数组
a + 1 - a = 10 等于1维数组大小,验证了a隐式转换后指向一维数组
a[0] + 1 -a[0] = 1;a[]其实也是数组名,隐式转换后指向数组元素
&a[0] + 1 -&a[0]等于一维数组的大小
&a[0][0] + 1 - &a[0][0] = 1;这个就不必说了