今天我们来学习通过指针来遍历一维数组,我们将通过指针的三种方法来实现。代码如下:
#include <stdio.h>
int main(int argc, const char * argv[]) {
int a[3]={1,2,3};
int *p = a;
for(int i=0; i<3; i++ )
{
int val = *(p+i);
printf("a[%d]=%d\n",i,val);
}
return 0;
}
上面的代码主要理解第7行代码和第11行代码即可。第7行代码中的 int *p = a,其中的a是数组名也是第一个数组元素的地址,相当于a[0]。第11行中的 (p+i)中的初始地址一直没变,一直都是a[0],相当于(a+i)。再在前面加一个*,即通过指针所指向当前地址找到对应的储存空间里的内容。
运行代码结果如下:
a[0]=1
a[1]=2
a[2]=3
其实上面代码中的第11行可以替换成 :
第二种方法:
int val = *(a+i);
int val=*(p++);
第三种方法,改变了指针。p++ 相当于 p=p+1;这里面的加1并不是指地址加1,这里会根据对应类型的指针变量加上相应储存空间的一个单位的地址空间。
运行结果都是相同的,不信的话,你可以试着敲一下代码运行一下。