数组指针(也称行指针)
定义: int (*p)[n]
;
()
优先级高,首先说明p
是一个指针,指向一个整型的二维数组,这个二维数组的长度是n
,也可以说是p
的步长,也就是说执行p+1
时,p
要跨过n
个整型数据的长度。
如要将二维数组赋给一指针,应这样赋值:
int a[3][4];
int (*p)[4]; //该语句是定义一个数组指针,指向含4个元素的一维数组。
p=a; //将该二维数组的首地址赋给p,也就是a[0]或&a[0][0]
p++; //该语句执行过后,也就是p=p+1;p跨过行a[0][]指向了行a[1][]
所以数组指针也称指向二维数组的指针,亦称行指针。
指针数组
定义:int *p[n]
;
[]
优先级高,先与p
结合成为一个数组,再由int*
说明这是一个整型指针数组,它有n
个指针类型的数组元素。
如要将一维数组赋给一指针数组:
int i;
int* p[3];
int a[3] = {0, 1, 2};
for (i = 0; i < 3; i++)
{
p[i] = a + i;
}
这里int *p[3]
表示一个一维数组内存放着三个指针变量,分别是p[0]
、p[1]
、p[2]
,所以要分别赋值。
优先级:()
>[]
>*