答案:1. 使用固定列数的二维数组,如void printArray(int arr[][3], int rows),可直接传递并遍历;2. 用指针方式传递,如void printArray(int (*arr)[3], int rows);3. 使用动态二维数组或vector提高灵活性。

在C++中,将二维数组传递给函数有几种常见方式。由于数组不能直接按值传递,必须通过指针或引用的方式处理。下面介绍几种实用且清晰的方法。
1. 使用固定列数的二维数组(最常用)
如果二维数组的列数在编译时是已知的,可以直接在参数中指定列数:
void printArray(int arr[][3], int rows) { for (int i = 0; i cout } cout调用示例:
int matrix[2][3] = {{1, 2, 3}, {4, 5, 6}}; printArray(matrix, 2);注意: 必须指定列数(这里是3),行数可以省略。
立即学习“C++免费学习笔记(深入)”;
2. 使用指向数组的指针
等价于第一种方法,语法更明确:
void printArray(int (*arr)[3], int rows) { for (int i = 0; i cout } cout这种写法明确表示 arr 是一个指向包含3个int的数组的指针。
3. 使用模板避免硬编码列数
如果你希望函数能自动适配不同大小的数组,可以用模板:
template这样调用时无需传行列数,类型自动推导:
int matrix[2][3] = {{1,2,3},{4,5,6}}; printArray(matrix); // 自动匹配4. 使用动态分配的二维数组(int**)
适用于运行时确定大小的情况,需手动管理内存:
void printArray(int** arr, int rows, int cols) { for (int i = 0; i cout } cout使用 new 分配:
int** matrix = new int*[2]; for (int i = 0; i5. 推荐:使用 std::vector(现代C++首选)
最安全、最灵活的方式:
void printArray(const vector调用:
vector优点:自动管理内存、支持变长、可拷贝、不易出错。
基本上就这些常见的传二维数组的方法。小项目可用固定列数方式,大型或复杂程序推荐使用 std::vector。关键是根据数组是否固定大小、是否动态分配来选择合适的方式。











