博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数组加1问题
阅读量:4618 次
发布时间:2019-06-09

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

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]*(ptr-1)就是a[4],执行结果是25

&a+1不是首地址+1,系统会认为加一个a数组的偏移,是偏移了一个数组的大小(本例是5int

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

ptr实际是&(a[5]),也就是a+5

原因如下:

&a是数组指针,其类型为 int (*)a[5];

而指针加1要根据指针类型加上一定的值,

不同类型的指针+1之后增加的大小不同

a是长度为5int数组指针,所以要加 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]. 

转载于:https://www.cnblogs.com/nktblog/p/4027094.html

你可能感兴趣的文章
LeetCode 4Sum
查看>>
(Kinetis K60)外部引脚中断
查看>>
[Loading Component]Loading组件的v-model设计是否不合理?
查看>>
博客园电子期刊2012年8月刊发布啦
查看>>
MVC – 7.Razor 语法
查看>>
windows环境中mysql忘记root密码的解决办法
查看>>
利用nginx向现有网站添加登录验证功能(不添加修改现有网站代码)
查看>>
Python pip国内源
查看>>
cocopod安装
查看>>
Atitit.数据索引 的种类以及原理实现机制 索引常用的存储结构
查看>>
哈夫曼树
查看>>
JS计算日期差
查看>>
2017最新高清仿驴妈妈旅行网大数据分析项目实战演练培训视频 228课
查看>>
数据结构综合性实验:多种功能的平衡二叉排序树
查看>>
[九度OJ]1011.最大连续子序列
查看>>
羊车门(作业)
查看>>
对C#中的Close()和Dispose()的浅显理解
查看>>
【手记】小心在where中使用NEWID()的大坑
查看>>
创建添加表格
查看>>
Javascript触屏手势库-JTouch
查看>>