使用new[]分配的动态数组必须用delete[]释放,避免内存泄漏和未定义行为。示例:int* arr = new int[10]; ... delete[] arr; arr = nullptr; 禁止混用delete与new[]。重复释放可通过置空指针防范,对nullptr调用delete[]安全。推荐优先使用std::vector或std::unique_ptr等智能指针管理动态数组,遵循RAII原则实现自动内存管理,减少手动操作带来的风险。

在C++中,动态数组的内存管理需要手动处理,如果操作不当容易导致内存泄漏、重复释放或野指针等问题。正确且安全地删除动态数组是每个C++开发者必须掌握的基本技能。
使用 new[] 分配的数组必须用 delete[] 释放
当你使用 new[] 动态创建数组时,必须使用 delete[] 来释放内存。这是C++语言的规定,否则行为未定义(undefined behavior),可能导致程序崩溃或资源泄露。
示例:
int* arr = new int[10]; // 分配10个int的数组
// ... 使用数组 ...
delete[] arr; // 正确释放数组内存
arr = nullptr; // 避免野指针
注意:不能使用 delete(不带方括号)来释放由 new[] 分配的内存,这会导致析构函数调用不完整或内存损坏。
避免重复释放和空指针检查
释放后的指针应立即设置为 nullptr,防止后续误操作造成二次释放。
立即学习“C++免费学习笔记(深入)”;
对空指针调用 delete[] 是安全的,C++标准保证这一点,因此无需额外判断是否为空再释放。
推荐写法:
delete[] arr;
arr = nullptr; // 清理指针
之后即使再次调用 delete[] arr;,也不会出错(因为arr是nullptr)。
优先使用智能指针或标准容器
最安全的方式是避免手动管理内存。C++提供了更安全的替代方案:
-
std::vector
:动态数组的首选,自动管理内存,支持动态扩容。 -
std::unique_ptr
:用于独占所有权的数组,自动调用 delete[]。 -
std::shared_ptr
:共享所有权的数组(需自定义删除器)。
使用 unique_ptr 管理数组:
std::unique_ptr
// ... 使用数组 ...
// 不需要手动 delete[],离开作用域自动释放
使用 vector 更简单:
std::vector
// 自动管理内存,无需 delete
总结关键点
安全释放动态数组的核心原则:
- new[] 搭配 delete[],不可混用。
- 释放后置空指针,防止误用。
- 优先使用 std::vector 或 std::unique_ptr
替代原始指针。 - RAII(资源获取即初始化)是C++推荐的资源管理方式。
基本上就这些。只要记住匹配释放、及时置空、优先用现代C++工具,就能避免绝大多数内存问题。











