1.对于一维数组 a[10],一级指针p
p=a;//把数组名(常量地址)赋值给了指针p(正确)
因为p是int指针,而数组名相当于int 常量,所以正确。
p=&a;//编译时就会出现错误,会显示警告:从不兼容的指针类型赋值。
那是因为&a是取数组a的地址,相当于int()[10]类型的数组指针,而指针p只是普通的一级指针,指向int型变量,不能随便赋值。
2.对于二维数组名与二级指针
定义:int a[2][5];
int **pa;
pa=a;//编译时会出现错误,会显示警告:从不兼容的指针类型赋值。
那是因为a指向一维的int数组。内存大小为sizeof(int)*数组长度;
而数组只是指向一个int *类型指针,内存大小为4,所以他们指向的类型是不相同的,不等价,因而无法将二维数组名赋值给二级指针。
3.对于二维数组名只能通过数组指针实现
例如:
int a[2] [5];
int *p[5];
p=a;//此时编译正确。二者等价,都是指向含有五个元素的一维数组。
相应的可以参考下面的代码:
#include<stdio.h>
int main()
{
int b[5],a[2][4];
int p,(*pa),(*p1)[4],(*p2)[4];
p=b;
pa=&p;
*pa=b;
p1=a;
printf("%p\n",p1);
printf("%p\n",*p1);
p2=a+1;
p1++;
printf("%p\n",p);
printf("%p\n",pa);
printf("%p\n",*pa);
printf("%p\n",p1);
printf("%p\n",*p1);
printf("%p\n",p2);
printf("%p\n",*p2);
return 0;
}