二维数组的首地址、首行地址和元素地址

首先定义一个简单的三行四列的数组:

int a[3][4] = { 1,2,3,4,5,6,7,8,9,10,11,12 };

 其中:

a代表第0行的首地址,其步长为一行的长度(16B),

所以a+1代表第1行的首地址,比a大16;a+2代表第2行的首地址,比a大32

 printf("a=%d  a+1=%d  a+2=%d\n", a, a+1,a+2);

&a[i]代表第i行首地址,等价于a+i

printf("&a[0]=%d  &a[1]=%d  &a[2]=%d\n\n", &a[0], &a[1], &a[2]);

输出结果为:

*a代表第0行第0个元素的地址,其步长为一个元素的长度(4B),所以*a+1比*a大4
*(a+1)代表第1行第0个元素的地址,比*a大一行的长度(16)
*(a+2)代表第2行第0个元素的地址,比*(a+1)大一行的长度(16)

printf("*a=%d  *a+1=%d  *(a+1)=%d  *(a+2)=%d\n", *a, *a + 1, *(a + 1), *(a + 2));

a[i]代表第i行首元素地址,等价于*(a+i)

printf("a[0]=%d  \t\t a[1]=%d  a[2]=%d\n\n", a[0], a[1], a[2]);

输出结果为:

&a代表整个数组的首地址,其步长为一个数组的大小(48B)
所以&a+1代表该数组最后一个元素的下个位置的地址,比a大48

printf("&a=%d  &a+1=%d\n\n", &a, &a + 1);

输出结果为:

*(a+i)+j代表第i行第j列元素的地址
*(a+0)+0代表第0行第0个元素,*a + 1代表第0行第1个元素,比*(a+0)+0大4
*(a+1)+1代表第1行第1个元素,比*(a+0)+0大20(差5个元素)

printf("*(a+0)+0=%d  *a+1=%d  *(a+1)+1=%d\n", *(a + 0) + 0, *a + 1, *(a + 1) + 1);

&a[i][j]代表第i行第j列元素的地址,等价于*(a+i)+j

printf("&a[0][0]=%d  &a[0][1]=%d  &a[1][1]=%d\n\n", &a[0][0], &a[0][1], &a[1][1]);

输出结果为:

&a与a与*a的值一样,但代表意义不同,实质是步长不同

*(*(a+i)+j)比*(a+i)+j外面多个*,代表第i行第j列元素的值,等价于a[i][j]

printf("*(*(a+0)+0)=%d  *(*(a+1)+1)=%d\n", *(*(a + 0) + 0), *(*(a + 1) + 1));

printf("a[0][0]=%d  a[1][1]=%d\n", a[0][0], a[1][1]);

 输出结果为:

猜你喜欢

转载自blog.csdn.net/Lemon_jay/article/details/83007589