#include <stdio.h> main() { int a[5] = {1,2,3,4,5}; printf("a=%p\n" , a); printf("a=%p\n" , &a); printf("a=%p\n" , &a+1); int *ptr = (int*)(&a+1); printf("%d %d\n" , *(a+1), *(ptr-1)); }
大家先看如上代码。然后猜测打印出a的内存地址和&a的内存地址是否一样?直觉上&a应该是对a这个指向a[0]指针变量取地址,所以猜测结果是不一样的。
但是,看输出结果。
a=0x7fff8178af30 &a=0x7fff8178af30 &a+1=0x7fff8178af44 2 5
答案是一样,这个是为什么呢?
a |
指向a数组a[0]元素的指针 |
&a | 指向整个a数组的指针 |
其实指向整个a数组的指针当然也是指向整个数组的起始地址也是a[0]。所以a和&a的内存地址指针也是一样的。虽然他们的内存指针地址是相同的。但是对这两个指针进行加减表示的含义是不同的。
a+1 | 指针移动sizeof(int)四个字节 |
&a+1 | 指针移动sizeof(a)二十个个字节 |