关于 (&a+1) 的困惑

在一次笔试过程中遇到的一个填空题,当时有些迷糊,回来上网查资料之后将解析贴出来共享一下。

请先看以下程序:

Q:

若 int a[5];

则 &a+1 的含义是甚么?

A:

&a+1 不是表示a的地址(设为Ox0010)加1,变为0x0011. 由于a为包括5个int类型的数组,则"&a+1"中的"+1"表示为相当于"1"个a大小的空间(或成为偏移),此时&a+1 表示 a[5].

Q:

若 int* ptr = (int*) (&a+1);

则 ptr 含义是甚么 ?

而 ptr - 1 又表示甚么 ?

A:

由于&a+1 表示 a[5], 则ptr即为a[5]。

又 ptr 为int型的指针,故 "ptr-1"则会减去"1"个int型指针的空间,此时即为a[5-1]=a[4].

//***************(转自http://sculibin.bokee.com/5628791.html)**************************************

看下面具体程序:

main()
{
    int a[5]={1,2,3,4,5};
    int *ptr=(int *)(&a+1);

    printf("%d,%d",*(a+1),*(ptr-1));
}
输出:2,5

Explanation:
*(a+1)就是a[1],*(ptr-1)就是a[4],执行结果是2,5
&a+1不是首地址+1,系统会认为加一个a数组的偏移,是偏移了一个数组的大小(本例是5个int)
int *ptr=(int *)(&a+1);
则ptr实际是&(a[5]),也就是a+5
原因如下:
&a是数组指针,其类型为 int (*)[5];
而指针加1要根据指针类型加上一定的值,
不同类型的指针+1之后增加的大小不同
a是长度为5的int数组指针,所以要加 5*sizeof(int)
所以ptr实际是a[5]
但是prt与(&a+1)类型是不一样的(这点很重要)
所以prt-1只会减去sizeof(int*)
a,&a的地址是一样的,但意思不一样,a是数组首地址,也就是a[0]的地址,&a是对象(数组)首地址,a+1是数组下一元素的地址,即a[1],&a+1是下一个对象的地址,即a[5].

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值