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

int *ptr=(int *)(&a+1)(面试题),有需要的朋友可以参考下。




【问题】:请写出以下程序的输出结果。



int main()
{
	int a[5]={1,2,3,4,5};
	int *ptr=(int *)(&a+1);
	printf("%d,%d\n",*(a+1),*(ptr-1));
}
【分析】:此题需要理解指针和数组的内在含义。  


【结果】:2,5


【理论知识】:我们首先需要搞明白a,&a.


a既是数据名,又是指向数组第一个元素的指针。


sizeof(a)=20, 此时a的类型为int[5]数组。


sizeof(*a)=4,因为有取值符*,表示把a当成一个指针(int*),而a指向数组的首地址,


即a=&(a[0]),即sizeof(*a)=sizeof(*&(a[0]))=sizeof(a[0])=sizeof(int)=4。


*(a+1)中把a当成一个指针,a+1=a+sizeof(int),a+1指向a的下一个整形地址既&a[1]。


因此*(a+1)=*(&a[1])=a[1]=2。


(&a+1)先取变量a的地址,并根据a的地址获得下一个与a同类型的相邻地址。根据前面所说的a的类型为int[5]数组。


&a+1=&a+sizeof(5*int),因此&a+1指向的地址为&a[5](数组a[5]的下一个地址)。


(int*)(&a+1)把这个相邻地址显式类型转换为int类型的地址int*ptr=(int*)(&a+1);


所以ptr指向&a[5],并且ptr是一个int类型的指针。


ptr-1=ptr-sizeof(int),故ptr-1指向&a[4]。因此,*(ptr-1)的值即为a[4]=5。


【个人理解】:


a[5]即可以看成是一个一维数组,也可以看成是一个只有一行的二维数组a[1][5]。


所以a指向一维数组的首地址,即a=&a[0],a+1指向&a[1]。每次加的地址长度为sizeof(int).


而&a指向二维数组的首地址,即&a=&a[0][5],&a+1指向&a[1][5]。每次加的地址长度为sizeof(5*int).

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值