int i_a[] = {1,2,3,4,5};
int *ptr1_pi = (int*)(&i_a + 1);
int *ptr2_pi = (int*)((int)i_a + 1);
printf("%x\t%x\n",ptr1_pi[-1],*ptr2_pi);
上面的一段代码是在《C语言深度剖析》里摘出来的,觉得有点意思,故这里转载之。
在gdb里我调试了一下截图如下:
这里(int)i_a是把数组i_a的值转换为int类型的数值,而不是地址,然后再加1,如上图所示,ptr1_pi[-1]的值大家应该知道,就是数组i_a的下一个数组,在返还一个数组元素,就指向了i_a[4]了,这个不难,ptr2_pi的值一目了然了吧,再截个图:
记得x86是小端模式。