将二维数组传递给函数时,形参类型必须包含数的大小声明符,C++ 需要这些信息才能正确地将下标数组引用(如 table[2][1])转换为存列储该元素的内存地址。
下面的程序演示了如何将一个二维数组传递给一个函数。以下是程序中函数 showArmy 的头文件:
showArray 函数可以接受任何二维整数数组,只要它有 4 列。在程序中,这个函数显示了两个独立数组的内容。
- // This program demonstrates how to pass
- // a two-dimensional array to a function.
- #include <iostream>
- #include <iomanip>
- using namespace std;
-
- const int NUM_COLS = 4; // Number of columns in each array
- const int TBL1_R0WS = 3; // Number of rows in table1
- const int TBL2_R0WS = 4; // Number of rows in table2
-
- void showArray(const int [][NUM_COLS], int); // Function prototype
-
- int main()
- {
- int table1[TBL1_R0WS][NUM_COLS] = {{1, 2, 3, 4},{5, 6, 7, 8},{9, 10, 11, 12} };
- int table2[TBL2_R0WS][NUM_COLS] = {{ 10, 20, 30, 40},{ 50, 60, 70, 80},{ 90, 100, 110, 120},{130, 140, 150, 160} };
- cout << "The contents of table1 are:\n";
- showArray(table1, TBL1_R0WS);
- cout << "\nThe contents of table2 are:\n";
- showArray(table2, TBL2_R0WS);
- return 0;
- }
- void showArray(int const array[][NUM_COLS], int numRows)
- {
- for (int row = 0; row < numRows; row++)
- {
- for (int col = 0; col < NUM_COLS; col++)
- {
- cout << setw (5) << array[row][col] << " ";
- }
- cout << endl;
- }
- }
程序输出结果:
由于二维数组存储在内存中,所以 C++ 要求在函数原型和函数头中指定列。一行实际上跟在另一行之后,如图 1 所示。
当编译器生成访问二维数组元素的代码时,需要知道行在内存中按多少个字节分隔开来,因此,列数是这个计算中的关键因素。
这个必要的列信息也可以用一个 typedef 声明来提供。以下是一个二维数组的 typedef 声明看起来的样子:
该语句使 intTable 成为具有任意行数和 4 列的二维数组的别名。如果这个 typedef 语句已经包含在此程序中,那么 showArray 函数的原型就可以写成如下形式:
其函数头则可以写成以下形式: