【二维指针与数组】
二维指针的形式大概有三种:1. int **P; 2. int *P[5]; 3. int (*P)[5];
相同点:都可用P[1][2]的形式访问。
①内容上,本身都是指针,最终代表的内容是整数。
②意义上,int **P 表示指向“一群”(指向整数的指针的)指针;——行列
int *P[ 5 ] 表示指向 5 个指向整数的指针的指针。——行 →↑↑↑↑
int ( *P)[ 5 ] 表示指向"一群"指向 5 个整数数 组的指针的指针。——列
③所占空间,int **P和 int ( *P )[ 5 ] 一样,在32位平台里,都是4字节,即一个指针。
但int *P[ 5 ] 不同,它是 5 个指针,它占5 * 4 = 20 个字节的内存空间。
用法:1.int **P
因为是指针的指针,需要两次内存分配才能使用其最终内容。
首先,P= ( int ** )new int *[ 5 ];这样分配好了以后,它和int *P[5]的意义就相同了;
然后要分别对 5 个指针进行内存分配,例如: P[ 0 ] = new int[ 20 ];
它表示为第 0 个指针分配 20 个整数,分配好以后, P[ 0 ]为指 向20个整数的数组。这时可以使用下标用法 P[ 0 ][ 0 ] 到 Ptr[ 0 ][ 19 ] 了。
如果没有第一次内存分配,该 P是个"野"指针,不能使用,如果没有第二次内存分配,则 P[ 0 ] 等也是个"野"指针,也是不能用的。当然,用它指向某个已经定义的地址则是允许的,那是另外的用法(类似于"借鸡生蛋"的做法),这里不作讨论(下同)。
2. int *P[ 5 ]
这样定义的话,编译器已经为它分配了 5 个指针的空间,这相当于(1)中的第一次内存分配。根据对(1)的讨论可知,显然要对其进行一次内存分配的。否则就是"野"指针。
3.int ( *P)[ 5 ]
这种定义我觉得很费解,不是不懂,而是觉得理解起来特别吃力,也许是我不太习惯这样的定义吧。怎么描述它呢?它的意义是"