答案:动态分配二维数组常用指针的指针方式,先分配行指针再逐行分配列空间,最后需依次释放每行内存并删除行指针。

在C++中,动态分配二维数组有多种方式,最常见的是使用指针的指针(int**)结合 new 和 delete 操作符。下面介绍几种常用方法,并说明如何正确释放内存以避免泄漏。
方法一:使用指针的指针(逐行分配)
这是最直观的方式,先分配一个指针数组,再为每一行分配空间。
示例代码:int rows = 3, cols = 4;
int** arr = new int*[rows]; // 分配行指针
for (int i = 0; i
arr[i] = new int[cols]; // 为每行分配列
}
使用完毕后必须按相反顺序释放:
for (int i = 0; i
delete[] arr[i]; // 先释放每行
}
delete[] arr; // 再释放行指针数组
arr = nullptr; // 避免悬空指针
方法二:一次性连续内存分配
这种方式更高效,内存是连续的,有利于缓存访问。
立即学习“C++免费学习笔记(深入)”;
int* arr = new int[rows * cols];
通过下标计算访问元素:arr[i * cols + j]
释放时只需一行:
delete[] arr;
优点是分配和释放简单,性能好;缺点是需要手动管理索引映射。
方法三:使用 std::vector(推荐)
现代C++推荐使用 std::vector 替代原始指针,自动管理内存。
#include
std::vector<:vector>> arr(rows, std::vector
可以直接用 arr[i][j] 访问,无需手动释放,超出作用域自动析构。
若对性能敏感且需要连续内存,可用单维vector模拟二维:
std::vector
arr[i * cols + j] = value;
注意事项
动态分配二维数组时需注意:
- 每次 new[] 必须对应一次 delete[],否则造成内存泄漏
- 不要混淆 delete 和 delete[],数组必须用 delete[]
- 分配失败时 new 会抛出异常,可配合 try-catch 处理
- 建议优先使用 RAII 原则,如 vector 或智能指针(如 std::unique_ptr)
基本上就这些。手动管理内存容易出错,除非有特殊需求,否则建议使用 std::vector 实现二维数组动态分配。










