int *ptr=(int *)(&a+1)问题的探讨

来源:互联网 发布:html手机游戏源码 编辑:程序博客网 时间:2024/05/16 06:20

转载地址:http://blog.sina.com.cn/s/blog_7420075e010129dv.html

http://bbs.csdn.net/topics/260069966



从网络上看到这样一道有意思的题目,是关于数组与指针的问题,描述如下:
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是数组指针,其类型为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]。


====================================

1,
int a[5]={1,2,3,4,5};
a  指向int的指针
&a 指向int[5]的指针
&a+1 == &a+sizeof(int[5])


2,
&(a+1)不能对表达式取址


可以改成
int *pp  = a + 1;
int *ptr = (int*)&pp;


====================================

可以这样理解


a是一个数组  那么a = a[0] 的地址 那么,&a 代表什么?(也是a[0]的地址),但是有什么区别呢?


假设 另一个指针 *p=&a 那么是不是有 **p=a呢 所以,这是一个2级指针,指向一个数组


那么 p+1 应该是指向数组的另一行……


那么 &(a)+1 就是指向数组另一行


这里 考虑多维数组的表示方式,多维数组在内存里,按照行(列)优先, 一般为行优先,排成一个一维数组的 ,


那么好了,你的 a 的下一行,当然就是从a[5] 开始了


0 0
原创粉丝点击