数组指针:
首先它是一个指针,指向数组。在32位系统中指针所占内存永远是4字节(64位中是8字节),但是指针所指向的数组长度不确定。
定义方法:int (*p)[n];
p是一个指针,指向一个一维数组,这里n表示一维数组的长度,也可以成为n的步长,即执行p+1时,p要跨过n个整型数据的长度。
int a[3][4];
int (*p)[4];
p = a;
p++;//执行之后p指向a[1]
因为p是一个指针,直接使用数组名是数组的首地址,把数组首地址赋给指针是合法的。
指针数组
指针数组是一个数组,这个数组的元素都是指针。数组占多少个字节由数组本身决定,但是每一个数组元素都是一个指针。
定义方法:int *p[n];
p是一个有n个数的数组,数组里元素的类型是 int*
如果int a[3][4]
这时p = a 是错误的,因为p是一个数组,不能把一个数组的地址赋给数组。但是可以*p = a , *p表示数组第一个元素的值,可以给第一个元素即一个指针赋首地址。
int a[3][4];
int *p[3];
for(int i = 0;i < 3;++i)
p[i] = a[i];
这里int *p[3] 表示一个一维数组内存放着三个指针变量,分别是p[0]、p[1]、p[2],所以要分别赋值。
对于以上两种数组:
比如要表示数组中i行j列一个元素:
(p[i]+j)、((p+i)+j)、((p+i))[j]、p[i][j]