智能指针通过RAII机制自动管理内存,避免泄漏和悬空指针。std::unique_ptr独占资源,不可复制但可移动;std::shared_ptr共享资源,引用计数为零时释放;std::weak_ptr观察shared_ptr对象,防止循环引用。优先使用make_unique和make_shared,避免裸new/delete,传参时根据需要选择const shared_ptr&或引用,合理使用三者提升代码安全性与可维护性。

智能指针是C++中用于自动管理动态内存的工具,主要目的是避免内存泄漏和悬空指针问题。它们通过RAII(资源获取即初始化)机制,在对象生命周期结束时自动释放所持有的资源。C++标准库提供了几种常用的智能指针:std::unique_ptr、std::shared_ptr 和 std::weak_ptr。
std::unique_ptr:独占所有权的智能指符
特点: 一个 unique_ptr 独占所指向对象的所有权,不能复制,但可以移动。
适用于需要确保某一时刻只有一个指针拥有资源的场景。
使用示例:- 创建方式:
auto ptr = std::make_unique(10); - 不能赋值或拷贝:
auto ptr2 = ptr;会编译失败 - 可以通过 move 转移所有权:
auto ptr2 = std::move(ptr); - 离开作用域时自动 delete 所指对象
适合用在局部资源管理、工厂函数返回值等场合。
立即学习“C++免费学习笔记(深入)”;
std::shared_ptr:共享所有权的智能指针
特点: 多个 shared_ptr 可以共享同一个对象,内部使用引用计数跟踪有多少指针指向该资源。当最后一个 shared_ptr 被销毁时,资源自动释放。
使用示例:- 创建方式:
auto sptr = std::make_shared(20); - 可复制:
auto sptr2 = sptr;,引用计数加1 - 每次析构一个 shared_ptr,引用计数减1,为0时释放资源
注意不要直接用裸指针构造多个 shared_ptr,会导致重复 delete。应优先使用 make_shared 提升性能并避免异常安全问题。
std::weak_ptr:配合 shared_ptr 防止循环引用
用途: weak_ptr 不增加引用计数,只是“观察” shared_ptr 所管理的对象,用于解决 shared_ptr 循环引用导致内存无法释放的问题。
- 不能直接解引用,需调用 lock() 获取临时 shared_ptr
- 若原对象已释放,lock() 返回 nullptr
父子节点互相持有 shared_ptr 会造成循环引用。将子节点对父节点的引用改为 weak_ptr,打破循环。
原理简析与最佳实践
智能指针的核心在于析构函数中自动调用 delete 或自定义删除器。同时支持数组和自定义删除逻辑(如关闭文件句柄、释放 GDI 资源等)。
- 优先使用 make_unique 和 make_shared,更安全高效
- 避免裸 new/delete,交给智能指针处理
- 小心 shared_ptr 的循环引用,及时引入 weak_ptr
- 函数传参时,若只是使用对象,建议传 const shared_ptr& 或直接引用对象
基本上就这些。合理使用这三种智能指针,能大幅降低C++内存管理出错的概率,让代码更健壮、易维护。











