首先定义一个简单的三行四列的数组:
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行首元素地址

本文深入探讨了C语言中三维四列数组的内存布局及访问方式,详细解释了数组的行优先存储原则,以及如何通过指针和下标运算访问数组元素。通过实例演示了数组基址、行首地址和元素地址的概念及其相互关系。
最低0.47元/天 解锁文章
8825





