#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]指针变量取地址,因此猜想结果是不同的。数组
可是,看输出结果。spa
a=0x7fff8178af30 &a=0x7fff8178af30 &a+1=0x7fff8178af44 2 5
答案是同样,这个是为何呢?指针
a | 指向a数组a[0]元素的指针code |
&a | 指向整个a数组的指针 |
其实指向整个a数组的指针固然也是指向整个数组的起始地址也是a[0]。因此a和&a的内存地址指针也是同样的。虽然他们的内存指针地址是相同的。可是对这两个指针进行加减表示的含义是不一样的。blog
a+1 | 指针移动sizeof(int)四个字节 |
&a+1 | 指针移动sizeof(a)二十个个字节 |