固定大小二维数组传参需指定列数,因编译器需知每行元素数以计算内存偏移,如void printArray(int arr3, int rows)。

在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
}
}
注意:列数(这里是4)必须在函数参数中给出,而行数可以省略或指定。
2. 使用指针数组或二级指针(适用于动态分配)
当使用动态分配的二维数组(如 int**)时,可以用二级指针传参:
示例代码:
立即学习“C++免费学习笔记(深入)”;
void printArray(int** arr, int rows, int cols) {
for (int i = 0; i
for (int j = 0; j
std::cout
}
std::cout
}
}
这种形式常用于 new 分配的二维数组或指针数组。
3. 使用一维指针并手动计算索引
将二维数组按行展开为一维数组传递,通过行和列手动计算位置:
示例代码:
立即学习“C++免费学习笔记(深入)”;
void printArray(int* arr, int rows, int cols) {
for (int i = 0; i
for (int j = 0; j
std::cout
}
std::cout
}
}
调用时传入 &array[0][0] 或数组名(对于连续内存的二维数组)。
4. 使用模板支持不同大小的数组
利用模板可以避免硬编码数组尺寸:
示例代码:
立即学习“C++免费学习笔记(深入)”;
template <size_t Rows, size_t Cols>
void printArray(int (&arr)[Rows][Cols]) {
for (int i = 0; i
for (int j = 0; j
std::cout
}
std::cout
}
}
这种方式可以在编译时推导数组维度,类型安全且高效。
基本上就这些常见方式。选择哪种写法取决于你是用栈上固定数组、动态分配,还是希望通用性更强。关键是理解二维数组在内存中的布局和函数如何正确访问它。


