文章开始我们先解释一下为什么 arr[i] == *(arr + i) 。
在C语言中,数组名代表的是数组中首元素的地址。在程序编译时,arr[i] 是按照 *(arr + i)处理的,即按照数组元素的首地址加上相应位移量找到新元素的地址,然后解引用,便得到此处的值。
接下来我们定义一个整形指针,通常会这么写 int *p = arr;这里为了方便理解我这样写也可以
int *p;
p = arr;
最后这句就可以看出来,p 和arr 是等价的。那么接下来的事情好办了,把文章开头的那个式子里的 arr 换成 p 怎么样?
P[i] == *(p + i)
这个合理吗?我们用程序说话:
int main()
{
int arr[] = {3,4,5,6,7}; // arr是数组名
//int *p = &arr;这句不对的原因很简单,因为arr本身就代表着一个地址
int *p = arr; // p 和 arr 是等价的
printf("%d\n",arr[2]);
printf("%d\n",*(arr + 2));
printf("%d\n",p[2]);
printf("%d\n",*(p + 2));
}
输出的全