前言:在我们来了解二维数组的传参之前,首先要了解二维数组在内存中是怎么存放的。在了解二维数组在内存中是怎么存放的之前不妨先了解一下一维数组在内存中是怎么存放的。
一维数组在内存中存放
我们可以先来写一个打印数组的每个元素的地址,然后来观察每个元素的地址的特点。
依次打印数组元素的地址:
输出结果我们看看:
从输出的结果我们分析,数组随着下标的增⻓,地址是由下到⼤变化的,并且我们发现每两个相邻的 元素之间相差4(因为⼀个整型是4个字节)。所以我们得出结论:数组在内存中是连续存放的。(当我们了解这个以后在二维数组的传参时就可以通过用指针的方式去传参)
二维数组在的传参
方法一:直接就将数组传给函数,函数的形参不是数组指针的情况。
方法二:函数的形参是数组指针的情况。
在用方法二之前,我们首先了解数组指针,在这里我们可以这样理解:⼆维数组其实可以看做是每个元素是⼀维数组的数组,也就是⼆维 数组的每个元素是⼀个⼀维数组。那么⼆维数组的⾸元素就是第⼀行,是个⼀维数组。
所以,根据数组名是数组⾸元素的地址这个规则,⼆维数组的数组名表⽰的就是第⼀⾏的地址,是⼀ 维数组的地址。根据上⾯的例⼦,第⼀⾏的⼀维数组的类型就是 型就是数组指针类型 int [5] ,所以第⼀⾏的地址的类 int(*)[5] 。那就意味着⼆维数组传参本质上也是传递了地址,传递的是第⼀ ⾏这个⼀维数组的地址,那么形参也是可以写成指针形式的。如下
总结:⼆维数组传参,形参的部分可以写成数组,也可以写成指针形式