int main()
{
int a[5] = {1, 2, 3, 4, 5};
int *ptr = (int*)(&a + 1);
printf("%d %d" , *(a + 1), *(ptr - 1));
//C++:cout << *(a + 1) << " " << *(ptr - 1);
{
int a[5] = {1, 2, 3, 4, 5};
int *ptr = (int*)(&a + 1);
printf("%d %d" , *(a + 1), *(ptr - 1));
//C++:cout << *(a + 1) << " " << *(ptr - 1);
}
这是由于类型的不同导致指针的解释不同。
首先a是一个数组名,它的类型应该是一个整型数组;而ptr是一个int型的指针。
所以a+1,a表示的是数组头元素的地址,是int型的,因此是在内存中移动一个数组元素大小的距离,也就是4;
而&a+1,&a是指向这个数组的地址,是int(*)[5],相等于一个指向数组的指针,在内存中是移动了一个数组对象的大小的距离,也就是20;
而指针ptr-1则只是移动了一个int指针对象大小的距离,也就是4。
所以对*(a+1)就是指数组第二个元素的值;(ptr-1)就是ptr的地址减去4,也就是指向数组最后一个元素的地址,解操作后就是数组最后一个元素的值。