【笔记】二维数组的内存布局

内存都是线性的,那么二维数组的存储是怎样的?
a[2][2]的内存布局如下图所示:
在这里插入图片描述
知道了内存分布,那么有一道例题:

int a[5][5];
int (*p)[4];
p = (int (*)[4])a;  //这里要强制转换,不然编译器会报错

printf("%d\n",&p[4][2] - &a[4][2]);

很明显a[5][5]的内存分布如下:
在这里插入图片描述
那p的内存分布呢?首先p是一个指针,是指向一个包含4个元素的数组的指针,并且当a作为右值赋给p时,a是作为数组首元素的首地址,也就是说,p的首地址就是a的首元素的首地址,即内存是重合部分的。如下图所示:
在这里插入图片描述
所以&p[4][2] - a[4][2]的答案就出来了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值