固定列数传参可用引用或指针,推荐引用传递以保留维度信息并确保安全。

在C++中,将二维数组作为函数参数传递有几种常见方式。关键在于理解数组名在传参时会退化为指针,以及如何正确声明形参以匹配实参的类型。
1. 固定列数的二维数组传参
如果二维数组的列数是固定的,函数参数可以直接声明为引用或使用固定大小的数组指针:
- 使用引用传递(推荐,安全且保留维度信息)
示例代码:
立即学习“C++免费学习笔记(深入)”;
void printArray(int (&arr)[3][4], int rows) {
for (int i = 0; i
for (int j = 0; j
std::cout
}
std::cout
}
}
- 使用指针形式(需指定列数)
示例代码:
立即学习“C++免费学习笔记(深入)”;
void printArray(int arr[][4], int rows, int cols) {
for (int i = 0; i
for (int j = 0; j
std::cout
}
std::cout
}
}
调用时传入实际数组即可:printArray(matrix, 3, 4);
2. 使用指向数组的指针
可以传递指向含有N个元素的一维数组的指针,适用于已知列数的情况。
示例:
void func(int (*arr)[4], int rows) {
// 使用方式与 arr[i][j] 相同
}
这种写法和 int arr[][4] 等价,只是语法不同。
3. 动态分配的二维数组或指针数组
对于动态创建的二维数组(如 int** 或 std::vector<:vector>>),传参方式不同。
- 使用二级指针(适用于动态分配的行指针数组)
示例:
void printMatrix(int** mat, int rows, int cols) {
for (int i = 0; i
for (int j = 0; j
std::cout
}
std::cout
}
}
注意:这种方式要求每行内存连续,且整体结构为指针数组。
4. 推荐使用 std::vector(现代C++做法)
更灵活、安全的方式是使用 std::vector<:vector>> 或一维向量模拟二维结构。
示例:
void printVector(const std::vector<:vector>>& vec) {
for (const auto& row : vec) {
for (int val : row) {
std::cout
}
std::cout
}
}
优点:自动管理内存,支持变长行列,避免指针错误。
基本上就这些。选择哪种方式取决于数组是否固定大小、是否动态分配,以及是否追求代码安全性。对于新项目,优先考虑 vector 形式。











