使用智能指针和RAII原则可有效防止内存泄漏:1. 优先使用std::unique_ptr和std::shared_ptr自动管理内存;2. 用std::make_unique和std::make_shared避免裸new;3. 异常安全的资源管理通过析构函数释放资源;4. 数组使用std::vector或std::array代替new[];5. 确保new[]与delete[]匹配,杜绝手动delete。

在C++中使用new和delete管理动态内存时,容易因忘记释放、异常中断或逻辑错误导致内存泄漏。要有效防止内存泄漏,关键在于确保每次new都有对应的delete,并遵循现代C++的资源管理原则。
使用智能指针替代裸指针
智能指针能自动管理对象生命周期,是防止内存泄漏最推荐的方式。
- std::unique_ptr:独占所有权,离开作用域时自动释放内存
- std::shared_ptr:共享所有权,引用计数为0时释放内存
- 避免使用
new直接初始化,改用std::make_unique或std::make_shared
auto ptr = std::make_unique(42); // 自动释放 // 不需要手动 delete
异常安全与RAII原则
当代码中抛出异常时,可能跳过delete语句,造成泄漏。RAII(资源获取即初始化)确保资源在对象构造时获取,析构时释放。
- 把资源封装在类中,在析构函数中调用
delete - 即使发生异常,局部对象也会被正确析构
class Buffer {
int* data;
public:
Buffer() : data(new int[100]) {}
~Buffer() { delete[] data; } // 异常安全释放
};
匹配使用 new/delete 和 new\[\]/delete\[\]
使用new[]分配数组时,必须用delete[]释放,否则行为未定义。
立即学习“C++免费学习笔记(深入)”;
- 不要混用
delete和delete[] - 优先使用
std::vector或std::array代替动态数组
int* arr = new int[10]; delete arr; // 错误!应使用 delete[]
避免裸 new/delete 的直接调用
现代C++提倡尽量不写new和delete。
- 用容器(如
std::vector,std::string)管理动态数据 - 函数返回对象而非指针,依赖移动语义提升性能
- 若必须使用原始指针,确保有明确的所有权约定
基本上就这些。只要坚持使用智能指针、遵守RAII、避免手动内存操作,就能大幅降低内存泄漏风险。C++的资源管理核心不是靠记得“delete”,而是靠设计让系统自动完成清理。











