数组与指针的不解之缘

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

#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;
}

访问后的结果图如下:

2015-04-03_100626

发表评论