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

来源:互联网 发布:淘宝奢侈品代购 编辑:程序博客网 时间:2024/04/29 19:16

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

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]。

#include "stdafx.h"#include <iostream>int _tmain(int argc, _TCHAR* argv[]){int a[] = {1,2,3,4,5};int *ptr = (int *)(&a + 1);std::cout<<"a:\t\t\t"<<a<<std::endl;std::cout<<"&a:\t\t\t"<<&a<<std::endl;std::cout<<"&a + 1:\t\t\t"<<&a + 1<<std::endl;std::cout<<"(int *)(&a + 1):\t"<<(int *)(&a + 1)<<std::endl;std::cout<<(char *)(&a+1) - (char *)a<<std::endl;std::cout<<*(&a) +1<<std::endl;std::cout<<std::endl;std::cout<<"a + 1:\t\t\t"<<a + 1<<std::endl;std::cout<<"ptr - 1:\t\t"<<ptr - 1<<std::endl;std::cout<<(*(a + 1))<<"\t"<<(*(ptr - 1))<<std::endl;return 0;}


原创粉丝点击