数组取址 和 ptr[-1]

int a[5]={1,2,3,4,5};
// 数组a的内存布局(16进制):01000000 02000000 03000000 04000000 05000000

int *ptr1=(int *)(&a+1);
// a本身就为一个数组的地址,其值=&a[0],即数组第一个元素的地址,对a再取址
// &a = a,似乎没什么不同,其实这里发生了对齐变更,a+1的对齐是以int为界的
// 而&a+1是以整个数组为单位的,即5个int=20字节,这是关键!!!
// 那么&a+1实际是跨越了整个数组,可得ptr1存储了数组a最后一个元素5紧跟着的一个int的地址


int *ptr2=(int *)((int)a+1);
// ptr2的值为a保存的地址值的绝对值+1,假设a=1000,那么(int)a+1=1001。
// 而后将其再转为(int *)指针,那么指针指向的内存布局为000000 02,即向后移了一个字节
// 那么在little-enddian架构下显示出来为02000000,低位在高地址。


int *ptr3=(int *)(a+1);
// a为数组首地址,a+1指向第二个元素

printf("%x,%x,%x\n",ptr1[-1],*ptr2,ptr3[-1]);
// 输出为:5,2000000,1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值