1. 数组指针
a pointer to an array,即指向数组的指针。
定义: int (*p)[n];
()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。
定义: int (*p)[n];
()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。
将二维数组赋给数组指针:
int a[3][4];
int (*p)[4]; //该语句是定义一个数组指针,指向含4个元素的一维数组。
p=a; //将该二维数组的首地址赋给p,此时p指向行a[0][]
p++; //p跨过行a[0][]指向了行a[1][]
2. 指针数组
array of pointers,即用于存储指针的数组,也就是数组元素都是指针。定义: int *p[n];
[]优先级高,先与p结合成为一个数组,再由int*说明这是一个整型指针数组,它有n个指针类型的数组元素。这里执行p+1时,则p指向下一个数组元素。
将二维数组赋给指针数组:
int a[3][4];
int *p[3]; //p[3] 表示一个一维数组内存放着三个指针变量,分别是p[0]、p[1]、p[2]
for(i=0; i<3; i++)
p[i]=a[i];
3.注意点
优先级:()>[]>*
访问
数组中i行j列的元素:*(p[i]+j)、*(*(p+i)+j)、(*(p+i))[j]、p[i][j]