c++++中智能指针的核心是shared_ptr和unique_ptr。1.shared_ptr适用于共享所有权场景,采用引用计数机制,适合多处共享资源的情况,但需注意避免循环引用,可通过weak_ptr解决;2.unique_ptr适用于独占所有权场景,不可复制只能移动,适合生命周期明确、无需共享的资源;3.选择策略上,优先用unique_ptr,若需多所有者则用shared_ptr;4.使用时应注意不要将同一原始指针交由多个智能指针管理,慎用栈对象绑定,数组资源需特殊处理,非内存资源可通过自定义删除器支持。

在C++中,智能指针是现代内存管理的核心工具。它们通过自动释放资源来避免内存泄漏和悬空指针等问题。其中,
shared_ptr和
unique_ptr是最常用的两种智能指针类型。它们各有适用场景,理解它们的机制和使用方式,能显著提升代码的安全性和可维护性。

shared_ptr:共享所有权的智能指针
shared_ptr实现的是引用计数机制。多个
shared_ptr可以指向同一个对象,当最后一个指向该对象的
shared_ptr被销毁或重置时,对象才会被释放。

使用建议:
- 适合需要多处共享资源的情况,比如数据结构之间的共享节点。
- 注意循环引用问题:如果两个对象互相持有对方的
shared_ptr
,会导致引用计数永远不为零,从而造成内存泄漏。- 解决办法:使用
weak_ptr
来打破循环依赖。
- 解决办法:使用
std::shared_ptrp1 = std::make_shared (42); std::shared_ptr p2 = p1; // 引用计数加1
小技巧:
- 推荐使用
std::make_shared
创建对象,它比直接构造更高效(一次内存分配)。 - 避免从原始指针构造
shared_ptr
,否则容易出错(如重复释放)。
unique_ptr:独占所有权的智能指针
unique_ptr表示对资源的唯一拥有权,不能复制,只能移动。这意味着资源只能由一个
unique_ptr管理,一旦离开作用域就会自动释放。
立即学习“C++免费学习笔记(深入)”;
使用建议:
- 适用于资源生命周期明确、不需要共享的场景,例如函数内部创建的对象。
- 更轻量、更快,因为它没有引用计数开销。
- 作为容器元素时非常安全,防止浅拷贝带来的问题。
std::unique_ptruptr = std::make_unique (100); // 不能复制:auto uptr2 = uptr; // 编译错误 auto uptr2 = std::move(uptr); // 合法,uptr变为空
常见用途:
- 返回值封装:函数返回
unique_ptr
表示调用者获得所有权。 - 工厂模式:用于生成对象并确保其正确释放。
shared_ptr 与 unique_ptr 的选择策略
如何决定使用哪种智能指针?可以遵循以下原则:

- 如果你确定只有一个所有者,优先使用
unique_ptr
。 - 如果你需要多个地方访问同一资源且不确定谁最后使用,用
shared_ptr
。 - 如果要传递
unique_ptr
到另一个函数或对象中,必须显式使用std::move()
,这有助于提高代码清晰度。
举个例子:
- GUI组件中的子控件通常由父控件拥有,这种一对一关系适合用
unique_ptr
。 - 网络连接池中的连接可能被多个线程同时访问,则更适合用
shared_ptr
。
内存管理细节注意点
有些细节容易被忽略,但影响很大:
- 不要把同一个原始指针交给多个智能指针管理,否则会触发未定义行为。
- 避免将栈上变量绑定到智能指针,除非你知道自己在做什么。
- 对于数组资源,
unique_ptr
支持数组形式(unique_ptr
),而shared_ptr
需要自定义删除器。
std::unique_ptrarr(new int[10]); // 正确 arr[0] = 1;
另外,对于非内存资源(如文件句柄、socket等),可以通过自定义删除器让智能指针管理这些资源,扩展性强。
基本上就这些。掌握好
shared_ptr和
unique_ptr的区别和应用场景,能让你写出更健壮、易维护的 C++ 代码。










