动态数组需配对使用new[]与delete[],释放后置空指针以防野指针;避免重复释放和内存越界,推荐优先使用std::vector或智能指针自动管理内存,结合AddressSanitizer等工具检测问题,确保内存安全。

在C++中,动态数组和指针紧密相关,正确管理内存是避免内存泄漏、野指针和程序崩溃的关键。使用不当容易引发严重问题,掌握释放动态数组和内存安全的技巧非常必要。
动态数组的申请与释放
使用 new[] 申请动态数组,必须用 delete[] 释放,否则会导致未定义行为或内存泄漏。
- 申请:int* arr = new int[10];
- 释放:delete[] arr; arr = nullptr;(释放后置空更安全)
- 错误示例:delete arr;(只释放第一个元素,其余内存泄漏)
避免重复释放与野指针
重复释放同一块内存会引发程序崩溃。释放后指针仍指向原地址,成为野指针,再次使用极其危险。
- 每次 delete[] 后将指针设为 nullptr,防止误操作。
- 确保每个 new[] 只对应一次 delete[],不要在多个地方重复释放。
- 函数返回动态数组时,明确文档责任归属,避免调用方忘记释放。
优先使用智能指针和标准容器
现代C++推荐用 std::vector 或 std::unique_ptr 替代原始动态数组,自动管理内存。
立即学习“C++免费学习笔记(深入)”;
- std::vector
arr(10); —— 自动扩容、自动释放。 - std::unique_ptr
ptr = std::make_unique (10); —— RAII 管理,出作用域自动释放。 - 减少手动 new/delete,从根本上避免内存问题。
检查内存越界与工具辅助
数组越界写入会破坏堆结构,导致释放时报错或崩溃。使用工具帮助检测。
- 避免访问 arr[-1] 或 arr[10](当大小为10时)。
- 使用 AddressSanitizer(ASan)编译选项检测越界和释放后使用。
- 调试阶段启用 -fsanitize=address,能快速定位内存问题。
基本上就这些。手动管理动态数组要格外小心,能用 vector 就不用裸指针,实在要用,记得配对 new[]/delete[],释放后置空,避免越界。安全习惯加上工具辅助,能大幅降低出错概率。










