如果定义一个数组a[ ],则数组名a和&a[0]表示数组首元素的地址,而&a则表示数组的首地址,通过下面这个经典的程序则可以理解它们的区别
# include <stdio.h>
int main(){
int a[5] = {1,2,3,4,5};
int* p = a+1;
int* pp = (int*)(&a+1);
printf("%d\n", *p);
printf("%d\n", *(pp - 1));
return 0;
}
在vs上运行结果为:
2
5
究其原因,首先要明确一点,指针加一则要根据指针的类型加上一定的数值。然后再来具体分析,数组名a为数组首元素a[0]的地址,它的类型为int*,指向一个int型元素的存储区域,因此(a+1)则指向了下一个元素即a[1] 。而&a表示数组的首地址,它的类型为int(*)[5],指向五个int型元素的存储区域,因此(&a+1)则越过数组指向下一块存储区域,但此处(int*)强制转换,pp为int*类型,因此(pp-1)左移一个sizeof(int)的大小,指向了a[4]。此程序的关键之处在于对&a进行了类型强制转化,改变了&a的类型。