动态内存分配通过new/new[]在堆上分配内存,new用于单个对象,new[]用于数组,分配失败时抛出bad_alloc异常;释放时必须用delete/delete[]配对,delete释放单个对象,delete[]释放数组,混用导致未定义行为;常见错误包括内存泄漏、重复释放、访问已释放内存和野指针,建议释放后置空指针;现代C++推荐使用智能指针如unique_ptr、shared_ptr和容器如vector,结合RAII原则自动管理内存,提升安全性和效率。

在C++中,动态内存分配和释放是程序运行时管理堆内存的核心机制。合理使用动态内存可以提升程序灵活性,但若处理不当,容易引发内存泄漏、野指针或重复释放等问题。掌握其基本规则对编写安全、高效的C++代码至关重要。
动态内存分配:new 和 new[]
使用 new 操作符可以在堆上分配单个对象的内存,而 new[] 用于分配对象数组。
例如:
int* pInt = new int; // 分配一个int类型的内存int* pArray = new int[10]; // 分配10个int的数组
new 成功时返回指向分配内存的指针,失败时抛出 std::bad_alloc 异常(除非使用nothrow版本)。
立即学习“C++免费学习笔记(深入)”;
动态内存释放:delete 和 delete[]
与 new 配对的是 delete,用于释放单个对象;与 new[] 配对的是 delete[],用于释放数组。
正确释放示例:
delete pInt; // 释放单个对象delete[] pArray; // 释放数组
关键规则:用 new 分配的内存必须用 delete 释放,用 new[] 分配的必须用 delete[] 释放。混用会导致未定义行为。
常见错误与注意事项
避免以下典型问题:
- 忘记释放内存:导致内存泄漏,程序长时间运行可能耗尽资源。
- 重复释放同一指针:调用 delete 多次会引发未定义行为。
- 访问已释放内存:指针变为野指针,读写将导致程序崩溃或数据损坏。
- delete 与 delete[] 混用:例如对 new[] 的结果使用 delete,行为未定义。
建议在释放后将指针置为 nullptr,防止误操作:
delete pInt;pInt = nullptr;
现代C++中的替代方案
手动管理内存风险高,现代C++推荐使用智能指针(如 std::unique_ptr、std::shared_ptr)和容器(如 std::vector)自动管理生命周期。
例如:
std::unique_ptr// 自动释放,无需手动 delete
使用RAII(资源获取即初始化)原则可大幅降低内存管理出错概率。
基本上就这些。掌握 new/delete 的配对使用规则,避免常见错误,优先考虑智能指针替代方案,是C++内存安全的基础。










