指针和数组
数组名是什么?
#include <Stdio.h>
int main()
{
int arr[10]={1,2,3,4,5,6,7,8,9,0}
printf("%p\n",arr);
printf("%p\n",&arr[0);
return 0;
}
上面代码的两个值时一样的,所以数组名代表数组首元素的地址(或者首元素的首地址)。 所以可以利用数组名遍历数组。
int main()
{
int arr[10]={0};
int* p=arr;
for(int i=0; i<10; i++)
{
*(p+i) = i;//解引用,得到第p+i个元素。
}
return 0;
}
这样数组就遍历为0~9。 根据上面代码,arr[2]== *(p+2)== *(2+p)。而p存放的是地址arr,所以可以得到 arr[2]== *(arr+2)== *(2+arr)。 最后2[arr]== *(2+arr),那么我们可以这样写代码吗?
int main()
{
int arr[10]={1,2,3,4,5,6,7,8,9,0};
printf("%d\n", 2[arr]);
printf("%d\n", arr[2]);
return 0;
}
打印出来的两个结果都是3,所以是可以用2[arr]的。那么为什么可以用呢?
当我们访问数组的时候[]是一个操作符,2和arr是两个操作数,加法有交换律,[]操作符同样有交换律,所以2和arr可以交换。运行的时候,编译器会将2[arr]转化为*(arr+2)来计算,就得到了第三个元素。同理也可以写成P[2]。
二级指针
指针可以指向一份普通类型的数据的地址,例如 int、double、char 等,也可以指向一份指针类型的数据的地址,例如 int *、double *、char * 等。
如果一个指针指向的是另外一个指针,我们就称它为二级指针,或者指向指针的指针。
int main()
{
int a=10;
int *pa=&a;
int **ppa=&pa;
return 0;
}
以上代码,指针pa指向a的地址,指针ppa指向指针变量pa的地址,指针ppa就被称为二级指针。同理也可以出现三级、四级指针。
所以二级指针ppa解引用一次得到pa,在解引用一次得到a。
指针数组
指针数组的主语是数组,所以它是一个有指针构成的数组。
int main()
{
int arr[10];//整型数组->存放整型数据的数组
char ch[5];//字符数组->存放字符的数组
//所以,指针数组就是存放指针的数组
int *parr[5];//存放整型指针的指针数组
char *pah[5];//存放字符指针的指针数组
return 0;
}