二维数组和二级指针传参问题

二维数组作为实参,二级指针作为形参
将二维数组直接传给二级指针是会报错的,原因是因为二维数组的二维是个假概念,在实际存储中都是一维存储。下面用例子来证明一下。

part1

报错:说我给二级指针传了一个数组指针去,数组指针(指向数组的指针),大概意思是我给一个二维形参,传了一个一维的实参。

在这里插入图片描述

part2

给二级指针传一个指针数组就可以解决了。
在这里插入图片描述

part3(总结)

把指针数组和数组指针好好区别一下!!!

1.指向数组的指针(数组指针/行指针):int (*array)[3];含义是一个指向存放3个整型数据的数组的指针
2.存放指针的数组(指针数组): char *array[3];含义是一个数组中存放了3个指向字符型数据的指针

关于二级指针和二维数组两者差别很大,不可以直接用二级指针传递二维数组

首先来看看二维数组在内存中是如何组织的呢?

一维数组 T arr1 = new T[9] ,二维数组T arr2 = new T[3][3]
在这里插入图片描述

C语言中的二级指针和二维数组问题

实际上,不管是一维还是多维数组,都是内存中一块线性连续空间,因此在内存级别上,其实都只是一维。但是不同的定义使得表现形式不一样,从而有多维数组的概念。访问数组元素其实非常简单,原因就在于元素在内存中的线性排列,这样对一维数组的访问只需要arr1[index]= (arr1+index*sizeof(T));对二维数组的访问arr2[i][j]=*(arr2+(i*col+j)*sizeof(T)),因此连续线性的数组访问效率很高。

具体分析移步https://www.linuxidc.com/Linux/2015-03/115055.htm

附加反汇编,一维和二维在存储空间的比较

在这里插入图片描述
分配row*col的内存,不足位用0填充
在这里插入图片描述

  • 2
    点赞
  • 9
    收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:游动-白 设计师:我叫白小胖 返回首页
评论

打赏作者

Matilda-sweet

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值