先看一道题:
1 #include2 3 void main() 4 { 5 int n[][3] = { 10,20,30,40,50,60}; 6 int (*p)[3]; 7 p=n; 8 cout << p[0][0] << "," << *(p[0]+1) << "," << (*p)[2] <
输出结果为:10,20,30
上题考察的数组指针和二维数组之间的关系,其中n是一个2*3的二维数组,p是一个数组指针,数组指针是一个指针,指向一个数组。这里的p在(*p)中,说明p是一个指针,指针的类型是int(*)[3],指针所指向的类型为int[3],所以指针p指向一个长度为3的数组。
一开始p指向n的第0行,因为第0行就是一个长度为3的数组。p[0]表示第0行的首地址(即&n[0][0]),p[0]+1表示第0行首地址偏移一个地址,即n[0][1]的地址(&n[0][1])。所以*(p[0]+1) 为n[0][1],答案是20。
p==&p[0],表示第0行(因为下标从0开始),所以*p == p[0],表示第0行的首地址,所以(*p)[2] 为p[0][2],即n[0][2],答案是30。
总结:
直接在p上移动就是移动行,在*p上移动就是移动列。比如:**(p+1)等于p[1][0],*(*p+1)等于p[0][1]。
未完待续~