数组与指针的不解之缘

2023-10-20 16:27:04 浏览数 (2)

所有数组名都表示数组的首地址,并且这个地址是个常量,是不可以被赋值的。既然是地址常量,从某种角度说,他也是个指针,所以数组名和指针是等同的。那么我们就可以非常灵活的使用指针及数组名来访问数组中的元素。可以注意看代码中最后几行访问数组的方式是多么的怪异,但的确它是可以的。

代码语言: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;
}

访问后的结果图如下:

0 人点赞