博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
int *ptr=(int *)(&a+1)问题的探讨
阅读量:5965 次
发布时间:2019-06-19

本文共 981 字,大约阅读时间需要 3 分钟。

从网络上看到这样一道有意思的题目,是关于数组与指针的问题,描述如下:

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

输出为:2,5

请解释以上代码的输出结果。

答案如下:

*(a+1)其实很简单就是指a[1],输出为2.

问题关键就在于第二个点,*(ptr-1)输出为多少?

解释如下,&a+1不是首地址+1,系统会认为加了一个整个a数组,偏移了整个数组a的大小(也就是5个int的大小)。所以int *ptr=(int *)(&a+1);其实ptr实际是&(a[5]),也就是a+5.

原因为何呢?

数组名a是一个地址常量,&a是数组指针,其类型为int(*)[5],也就是指向int[5]这个类型的一个指针;

而指针加1要根据指针类型加上一定的值,不同类型的指针+1之后增加的大小不同,a是长度为5的int数组指针,所以要加5*sizeof(int),所 以ptr实际是a[5],但是ptr与(&a+1)类型是不一样的,这点非常重要,所以ptr-1只会减去 sizeof(int*),a,&a的地址是一样的,但意思就不一样了,a是数组首地址,也就是a[0]的地址,&a是对象(数组)首地 址,a+1是数组下一元素的地址,即a[1],&a+1是下一个对象的地址,即a[5]。

 

另外一个例子,方便看出地址的区别:

int main(int argc, char *argv[]){    int i;    int a[]={
1, 2, 3, 4, 5}; int s; int *p = (int *)(&a+1); printf(" a = %p\n&a = %p\n", a, &a); for(i = 0; i < 5; i++) printf("a[%d] = %p\n", i, &a[i]); printf(" p = %p\n&p = %p\n&s = %p\n", p, &p, &s); return 0;}

 

转载于:https://www.cnblogs.com/fightformylife/p/4065129.html

你可能感兴趣的文章
理解 Glance - 每天5分钟玩转 OpenStack(20)
查看>>
Unshelve Instance 操作详解 - 每天5分钟玩转 OpenStack(39)
查看>>
init.d文件夹 2012-02-09
查看>>
CKeditor的几种配置方式
查看>>
解决Android 输入法InputMethodService 显示时让原Activity大小计算错误问题
查看>>
s3c6410烧写u-boot&&Linux
查看>>
R语言 par()函数
查看>>
云计算是否为数据仓储做好了准备呢?
查看>>
TensorBoard:嵌入可视化
查看>>
TensorBoard:图形可视化
查看>>
Esper 20章 优化
查看>>
Disruptor 创建过程
查看>>
我的友情链接
查看>>
进位计数制
查看>>
C++模板之一:函数模板.odt
查看>>
申请google Map api key for android
查看>>
FreeSWITCH的NAT穿越
查看>>
gitlab版本控制系统源码部署
查看>>
java反射机制中的getDeclaredField()
查看>>
java数据流无法输出验证码
查看>>