所有数组名都表示数组的首地址,并且这个地址是个常量,是不可以被赋值的。既然是地址常量,从某种角度说,他也是个指针,所以数组名和指针是等同的。那么我们就可以非常灵活的使用指针及数组名来访问数组中的元素。可以注意看代码中最后几行访问数组的方式是多么的怪异,但的确它是可以的。
#include <stdio.h> int main(int argc, char* argv[]) { int arr[] = { 1, 2, 3, 4, 5, 10 }; int i; int *pArr = arr; for (i = 0; i < 6; i++) { // 标准下标访问 printf("%d ", arr[i]); // 指针下标访问,pArr指向的地址与arr相同 printf("%d ", pArr[i]); // 把数组名看作数组第一个元素首地址,+ i后向后偏移,再使用*间接引用 printf("%d ", *(arr + i)); // 把指针看作数组第一个元素首地址,+ i后向后偏移,再使用*间接引用 printf("%d ", *(pArr + i)); // 等同于printf("%d ", *(arr + i)); printf("%d ", *(i + arr)); // 等同于printf("%d ", *(pArr + i)); printf("%d ", *(i + pArr)); // 怪异的写法,等同于printf("%d ", *(i + arr));两种汇编代码是一样的 printf("%d ", i[arr]); // 怪异的写法,等同于printf("%d ", *(i + pArr));两种汇编代码是一样的 printf("%d ", i[pArr]); printf("\n"); } getchar(); return 0; }
访问后的结果图如下: