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

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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]);

 输出结果为:

 

 

评论 17
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值