首页 > 代码库 > 二维数组如何作为函数参数使用?(转)
二维数组如何作为函数参数使用?(转)
如果我们需要编写一个处理二维数组的函数,那么这个函数原型应该如何声明呢?
首先,我们应该牢记:数组名被视为其地址,因此,相应的形参是一个指针。例如,假设有如下的代码:
[cpp] view plaincopy
- int data[3][4] = { {1, 2, 3, 4}, {5, 5, 7, 8}, {9, 10, 11, 12} }
- int total = sum(data, 3);
我们可以这样理解:data 是一个数组名,该数组有3个元素。而这3个元素本身都是又4个 int 组成的数组。因此 data 的类型是 指向由4个int组成的数组的指针。
因此正确的 sum 原型如下:
[cpp] view plaincopy
- int sum( int (*arr) [4], int size);
- //其中的括号是必不可少的,因为下面的声明将声明一个由四个指向int的指针组成的数组,而不是一个指向由4个int组成的数组的指针。
- int *arr[4]; //声明了一个指针数组,这个数组包含4个int指针变量
- int (*arr)[4] //声明了一个指针变量,这个指针指向由4个int组成的数组
还有另外一种声明格式,含义与上述正确原型完全相同,但是可读性更强:
[cpp] view plaincopy
- int sum(int arr[][4], int size);
上述2个原型都指出,arr 是指针而不是数组。还需要注意的是:int arr [ ] [4] 的含义就是: arr 是指向由4个 int 构成的数组的指针。因此,指针类型指定了列数,也就是说:函数形参已经确定了实参数组的列数,这就是为什么没有将列数作为独立的函数参数进行传递的原因。
二维数组如何作为函数参数使用?(转)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。