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

在C++中,将二维数组作为函数参数传递有几种常见方式。关键在于理解数组名在传参时会退化为指针,以及如何正确声明形参以匹配实参的类型。
如果二维数组的列数是固定的,函数参数可以直接声明为引用或使用固定大小的数组指针:
示例代码:
立即学习“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);
可以传递指向含有N个元素的一维数组的指针,适用于已知列数的情况。
示例:
void func(int (*arr)[4], int rows) {
// 使用方式与 arr[i][j] 相同
}
这种写法和 int arr[][4] 等价,只是语法不同。
对于动态创建的二维数组(如 int** 或 std::vector<:vector>></:vector>),传参方式不同。
示例:
void printMatrix(int** mat, int rows, int cols) {
for (int i = 0; i
for (int j = 0; j
std::cout
}
std::cout
}
}
注意:这种方式要求每行内存连续,且整体结构为指针数组。
更灵活、安全的方式是使用 std::vector<:vector>></:vector> 或一维向量模拟二维结构。
示例:
void printVector(const std::vector<:vector>>& vec) {
for (const auto& row : vec) {
for (int val : row) {
std::cout
}
std::cout
}
}
优点:自动管理内存,支持变长行列,避免指针错误。
基本上就这些。选择哪种方式取决于数组是否固定大小、是否动态分配,以及是否追求代码安全性。对于新项目,优先考虑 vector 形式。
以上就是c++++怎么将二维数组作为函数参数_二维数组参数传递方式的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号