数组指针(也称为 行指针)
定义:
指向一维数组的指针。 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跨过了行a[0][] 指向了 a[1][]

指针数组
定义:
int *p[n];
[]优先级高, 先与p结合成为一个数组,再有 int* 说明这是一个整型指针数组,它有n个指针类型的数组元素, 大专栏 指针数组和数组指针在这里执行p+1是错误的, p = a 这样的赋值也是错误的, 因为p是个不可知的表示, 只存在p[0]、p[1]、p[2]、….p[n-1], 并且他们分别是指针变量可以用来存放变量地址。
*p = a //这里*p表示指针数组第一个元素的值,a的首地址的值。
如果要将二维数组赋值给一 指针数组:
int *p[3]; int a[3][4]; for(int i = 0; i < 3; i++) { p[i] = a[i] } 这里的 int *p[3] 表示一个一维数组内存放着三个指针变量。 p[0]、 p[1]、 p[2] 所以要分别赋值。

这样两者的区别就豁然开朗了,数组指针只是一个指针变量,似乎是C语言里专门用来指向二维数组的,它占有内存中一个指针的存储空间。指针数组是多个指针变量,以数组形式存在内存当中,占有多个指针的存储空间。 还需要说明的一点就是,同时用来指向二维数组时,其引用和用数组名引用都是一样的。 比如要表示数组中i行j列一个元素:
*(p[i]+j)、*(*(p+i)+j)、(*(p+i))[j]、p[i][j]