智能指针是C++11引入的自动内存管理机制,核心在于正确选用unique_ptr(独占、零开销)或shared_ptr(共享、带引用计数),避免裸指针混用、循环引用等误用。

智能指针是 C++11 引入的核心机制,用来自动管理动态分配的内存,避免手动 new/delete 带来的泄漏、重复释放和悬空指针问题。关键不是“用不用”,而是“怎么用对”——shared_ptr 和 unique_ptr 解决不同场景,选错反而引入新问题。
unique_ptr:独占所有权,轻量高效
unique_ptr 表示资源只能被一个指针拥有,不可复制,但可移动。它几乎零开销(不带引用计数),适合绝大多数需要堆内存但不需要共享的场景,比如容器元素、函数返回临时资源、RAII 封装等。
- 创建用
std::make_unique<t>()</t>,别直接 new —— 安全且简洁:auto p = std::make_unique<int>(42);</int> - 不能赋值或拷贝:
auto q = p; // ❌ 编译失败auto r = std::move(p); // ✅ 转移所有权,p 变为空 - 支持自定义删除器(比如关闭文件、释放 C 风格资源):
auto fp = std::unique_ptr<file decltype>(fopen("a.txt", "r"), &fclose);</file>
shared_ptr:共享所有权,带引用计数
shared_ptr 允许多个指针共同拥有同一块资源,内部维护引用计数。当最后一个 shared_ptr 被销毁或重置时,资源才被释放。适用于真正需要共享访问的场景,比如对象图、观察者模式、缓存等。
- 优先用
std::make_shared<t>()</t>创建 —— 一次分配对象+控制块,比new+ 构造更高效:auto sp = std::make_shared<:string>("hello");</:string> - 可拷贝、可赋值,引用计数自动增减:
auto sp2 = sp; // 计数+1sp.reset(); // 计数-1,若为0则释放资源 - 注意循环引用:两个
shared_ptr互相持有会导致计数永不归零。破环用weak_ptr(只观察不参与计数):std::weak_ptr<node> parent_ref;</node>
常见误用与避坑点
智能指针不是万能胶,用错会埋雷:
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~