C++多维数组指针与函数传递方法

答案:多维数组在C++中以连续内存存储,传参时需指定除第一维外的维度大小,因编译器需据此计算地址偏移;二维数组名退化为指向行的指针(如int ()[4]),可通过函数参数int (matrix)[4]或模板int (&arr)Rows传递,确保类型匹配与正确访问元素。

c++多维数组指针与函数传递方法

在C++中,多维数组的指针操作和函数传递是一个容易混淆但非常实用的知识点。理解其本质有助于写出更高效、灵活的代码。多维数组本质上是一段连续的内存空间,通过指针对其进行访问和传递时,需要明确数组的维度和类型匹配。

以二维数组为例:


int arr[3][4]; // 3行4列的二维数组

这个数组名 arr 的类型是 int [3][4],当它退化为指针时,类型变为 int (*)[4] —— 指向包含4个整数的数组的指针。

关键点:

立即学习“C++免费学习笔记(深入)”;

  • arr 是指向第一行(即 arr[0])的指针,类型为 int (*)[4]
  • arr[i] 是第 i 行首元素的地址,类型为 int*
  • arr[i][j] 是具体的值,类型为 int

函数参数中不能直接写 int arr[][] 这样的形式(除第一维外,其余维度必须指定),因为编译器需要知道每一行的大小才能正确计算偏移。

正确的函数声明方式:


void func(int (*matrix)[4], int rows) {
// 使用 matrix[i][j] 访问元素
}
// 或等价写法:
void func(int matrix[][4], int rows)

调用示例:


int data[3][4] = {{1,2,3,4}, {5,6,7,8}, {9,10,11,12}};
func(data, 3);

注意:第二维(列数)必须在函数参数中明确写出,否则无法确定每行字节数,导致指针运算错误。

如果希望函数能接受不同尺寸的多维数组,可以使用模板:


template
void printArray(int (&arr)[Rows][Cols]) ">mysql如何实现房间与订单的关联关系