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).

你可能感兴趣的:(企业面试题)