数组指针、二维数组名代表的是什么?

#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之外还有一些其他的字符,即类似于“abcdj”这样的东西。原因和第1点相同,程序以找到‘\0’为结束输出标志,输出abcd之后,由于没有找到’\0’,所以就继续输出奇怪字符了;
4、请注意上述代码中是如何通过指针来对二维数组进行操作的,不是通过二级指针(形如:char **p)!是通过一级指针,只不过这个指针指向的数据类型还是一个一维数组而已!那二级指针有什么用?和一级指针的用法是类似的,一级指针是用来干嘛的?在进行函数的参数传递的时候,通过一级指针进行参数传递,可以在子函数内修改指针指向的内容。那么同样的,通过一级指针的指针(即二级指针)进行函数的传参,在子函数内可以修改该一级指针的指向。详细见[2]

参考:
[1] sizeof(数组名)和sizeof(指针)
[2] 二级指针的作用详解
[3] 二维数组和二级指针(真的没什么关系)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值