#include<stdio.h>
void main()
{
int a[10]={1,3,5,6,7};
int b[3]={2,4,6};
int (*p)[2];
p=&a;
printf("%d/n",(*p)[0]);//指向a数组的首元素因为*p=a,这里等于写a[0]
printf("%d/n",(*p)[1]);//同上
printf("%d/n",*p[0]);//同前一例
printf("%d/n",*p[1]);//数组内存空间连续的特性,所以返回a数组的第3个值
}
#include<stdio.h>
void main()
{
int a[10]={1,3,5,6,7};
int b[3]={2,4,6};
int (*p)[10];
p=&a;
printf("%d/n",(*p)[0]);//指向a数组的首元素因为*p=a,这里等于写a[0]
printf("%d/n",(*p)[1]);//同上
printf("%d/n",*p[0]);//p[0]包含了整个a数组,所以这里返回a的首元素
printf("%d/n",*p[1]);//没有指向
}
a数组有10个大小,第一个例子里p数组也有10个大小,然后p=&a,p[0]里装的是a数组,p[1]里装的是a数组后面那段空间,依次类推
而第二个例子里,p数组只有两个大小,p[0]同样装的是a数组的值,但是装不下,而p[1]和p[0]是连续的,所以就形成这样的状态
当表示为*p[0]的时候,已经把整个a都包含了,而当(*p)[10] 时就既指向一个十个元素的一维数组,所以当*p[1]时已经超出 a的范围, 但当(*p)[2] 是指向一个二元素的一维数组,但它并未把 a 全部包含,再根据数组的连续特性,*p[1]应该是指负 a 的第三个元素
另外,这里是属于二维指针,*p[0]代表行指针,要访问0行中的列就要*(p[0]+1)这样访问, 如果是 *p[1] 就是第二行了.