#include <iostream>
using namespace std;
int main()
{
char a[3][2] = {{'a','b'},{'c','d'}}; //a是一个大小为3的一维数组,数组中的每个元素都指向一个char [2]类型的数据;
char (*b)[2] ; //b是一个指向char数组的指针,数组的大小是2;
b = a; //从这儿可以看出二维数组名代表一个指向char [2]类型的指针
cout << sizeof(*b) << endl; //输出2,即b指针所指向的类型(char [2])的大小=1*2=2;
cout << sizeof(*a) << endl; //输出2;
cout << *a << endl; //输出abcd。原因见下面的解释1
cout << *b << endl; //输出abcd
cout << *(a+2) << endl; //无输出,原因见下面的解释2;
int A[10];
int* B=new int[10];
cout << sizeof(A) <<endl; //40, 即10*4=40
cout << sizeof(B) << endl; //4,即指针本身占据的空间是32位=4字节;
return 0;
}
之所以会出现上面的输出结果是因为:
1、cout在输出字符数组时,类似于c语言使用s%进行格式化输出,因此在输出*a时,通过’\0’来停止输出,所以即使b指针指向的类型是 char [2],系统输出ab之后,由于没有发现’\0’,就继续输出cd字符。
2、由于一个3行2列的二维数组,前两行赋了初值abcd,第三行由于没赋值,我猜测系统可能在’d’字符的下一字节赋值了’\0’,所以系统在输出时,输出到d就结束了。
3、假如说我们把a[3][2]这个二维数组的行数改为2行,即a[2][2],程序输出时,除了abcd之外还有一些其他的字符,即类似于“abcdj”这样的东西。原因和第1点相同,程序以找到‘\0’为结束输出标志,输出abcd之后,由于没有找到’\0’,所以就继续输出奇怪字符了;
4、请注意上述代码中是如何通过指针来对二维数组进行操作的,不是通过二级指针(形如:char **p)!是通过一级指针,只不过这个指针指向的数据类型还是一个一维数组而已!那二级指针有什么用?和一级指针的用法是类似的,一级指针是用来干嘛的?在进行函数的参数传递的时候,通过一级指针进行参数传递,可以在子函数内修改指针指向的内容。那么同样的,通过一级指针的指针(即二级指针)进行函数的传参,在子函数内可以修改该一级指针的指向。详细见[2]
参考:
[1] sizeof(数组名)和sizeof(指针)
[2] 二级指针的作用详解
[3] 二维数组和二级指针(真的没什么关系)