使用智能指针可有效避免C++内存泄漏:std::unique_ptr独占资源,离开作用域自动释放;std::shared_ptr通过引用计数实现共享所有权,计数为零时释放资源;循环引用问题可用std::weak_ptr解决,其不增加引用计数,需lock()访问对象。优先使用make_unique和make_shared,避免裸new/delete,能大幅减少内存泄漏风险。

在C++中,内存泄漏通常是因为动态分配的内存没有被正确释放。使用智能指针可以有效避免这类问题,因为它们能自动管理对象的生命周期。核心思路是让智能指针在适当的时候自动调用
delete,从而确保内存被释放。
使用std::unique_ptr管理独占资源
std::unique_ptr用于表示某个对象的唯一所有权。当unique_ptr离开作用域时,它所管理的对象会自动被删除。
适用于不需要共享所有权的场景,比如函数内部创建对象:
- 创建方式:
std::unique_ptr
ptr = std::make_unique (); - 不能复制,但可以移动:避免多个指针指向同一对象
- 离开作用域自动释放内存,无需手动调用delete
使用std::shared_ptr实现共享所有权
std::shared_ptr允许多个指针共享同一个对象,内部使用引用计数机制。当最后一个shared_ptr被销毁时,对象自动释放。
立即学习“C++免费学习笔记(深入)”;
适合多个部分需要访问同一资源的场景:
- 创建方式:
std::shared_ptr
ptr = std::make_shared (); - 每次复制shared_ptr,引用计数加1;销毁时减1
- 引用计数为0时自动释放资源
警惕循环引用:使用std::weak_ptr
当两个shared_ptr互相持有对方时,会导致引用计数无法归零,从而引发内存泄漏。此时应使用std::weak_ptr打破循环。
weak_ptr不增加引用计数,只是临时观察对象是否存在:
- 用于监听shared_ptr管理的对象,不参与生命周期管理
- 访问前需调用
lock()
检查对象是否还存在 - 常见于观察者模式或父子节点互相引用的结构
基本上就这些。只要优先使用make_unique和make_shared,避免裸new/delete,再注意循环引用问题,就能大幅减少甚至消除内存泄漏。智能指针不是万能的,但它们是现代C++资源管理的基石。










