所有数组名都表示数组的首地址,并且这个地址是个常量,是不可以被赋值的。既然是地址常量,从某种角度说,他也是个指针,所以数组名和指针是等同的。那么我们就可以非常灵活的使用指针及数组名来访问数组中的元素。可以注意看代码中最后几行访问数组的方式是多么的怪异,但的确它是可以的。
代码语言:javascript复制#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;
}
访问后的结果图如下: