您的位置:首页 > 其它

二维数组

2016-03-31 11:28 260 查看
如果我们需要编写一个处理二维数组的函数,那么这个函数原型应该如何声明呢?

首先,我们应该牢记:数组名被视为其地址,因此,相应的形参是一个指针。例如,假设有如下的代码:

[cpp] view
plain copy

 





int data[3][4] = { {1, 2, 3, 4}, {5, 5, 7, 8}, {9, 10, 11, 12} }  

int total = sum(data, 3);  

那么sun函数的原型应该如何声明呢?为什么将行数3作为参数,而不将列数4作为参数呢?

我们可以这样理解:data 是一个数组名,该数组有3个元素。而这3个元素本身都是又4个 int 组成的数组。因此 data 的类型是 指向由4个int组成的数组的指针。

因此正确的 sum 原型如下:

[cpp] view
plain copy

 





int sum( int (*arr) [4], int size);  

//其中的括号是必不可少的,因为下面的声明将声明一个由四个指向int的指针组成的数组,而不是一个指向由4个int组成的数组的指针。  

  

int *arr[4];   //声明了一个指针数组,这个数组包含4个int指针变量  

int (*arr)[4] //声明了一个指针变量,这个指针指向由4个int组成的数组  

还有另外一种声明格式,含义与上述正确原型完全相同,但是可读性更强:

[cpp] view
plain copy

 





int sum(int arr[][4], int size);  

上述2个原型都指出,arr 是指针而不是数组。还需要注意的是:int arr [ ] [4] 的含义就是: arr 是指向由4个 int 构成的数组的指针。因此,指针类型指定了列数,也就是说:函数形参已经确定了实参数组的列数,这就是为什么没有将列数作为独立的函数参数进行传递的原因。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: