#include <stdio.h> int main() { int intArray[] = {1, 2, 3, 4, 5}; int *p = (int *)(&intArray+1); printf("%d,%d",*(intArray+1),*(p-1)); return 0; }
*(intArray+1)其实很简单就是指intArray[1],输出为2.
问题关键就在于第二个点,*(p-1)输出为多少?
解释如下,&intArray+1不是首地址+1,系统会认为加了一个整个intArray数组,偏移了整个数组intArray的大小(也就是5个int的大小)。所以int*p=(int*)(&intArray+1);其实ptr实际是&(intArray[5]),也就是intArray+5.
原因为何呢?
&intArray是数组指针,其类型为int(*)[5];
而指针加1要根据指针类型加上一定的值,不同类型的指针+1之后增加的大小不同,intArray是长度为5的int数组指针,所以要加5*sizeof(int),所以p实际是intArray[5],但是p与(&intArray+1)类型是不一样的,这点非常重要,所以p-1只会减去sizeof(int*),intArray,&intArray的地址是一样的,但意思就不一样了,intArray是数组首地址,也就是intArray[0]的地址,&intArray是对象(数组)首地址,intArray+1是数组下一元素的地址,即intArray[1],&intArray+1是下一个对象的地址,即intArray[5]。