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

智能指针是 C++11 引入的核心机制,用来自动管理动态分配的内存,避免手动 new/delete 带来的泄漏、重复释放和悬空指针问题。关键不是“用不用”,而是“怎么用对”——shared_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 变为空
auto fp = std::unique_ptr<file decltype>(fopen("a.txt", "r"), &fclose);</file>
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>
智能指针不是万能胶,用错会埋雷:
立即学习“C++免费学习笔记(深入)”;
new 分配后又用 shared_ptr 接管,再手动 delete,必崩溃。this 直接传给 shared_ptr —— 会造成双重管理。要用 enable_shared_from_this:class A : public std::enable_shared_from_this<a> { ... };</a>auto self = shared_from_this(); // ✅ 安全获取 shared_ptr<a></a>
shared_ptr<t></t>(C++17 起支持):auto arr = std::make_shared<int>(100); // ✅</int>auto raw = std::shared_ptr<int>(new int[100], [](int* p) { delete[] p; }); // ❌ 过时写法,尽量避免</int>
问自己一个问题:这块内存,是否**必须**由多个所有者共同决定生命周期?
unique_ptr(默认选择,更安全、更快、更清晰)weak_ptr 观察);如果确实需要共享 → 用 shared_ptr,并警惕循环引用基本上就这些。不复杂,但容易忽略细节。
以上就是C++如何使用智能指针?(shared_ptr/unique_ptr详解)的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号