答案:unique_ptr独占所有权,不可复制但可移动,离开作用域时自动释放资源;shared_ptr通过引用计数共享所有权,允许多个指针共享同一对象,最后一个shared_ptr销毁时释放资源;推荐优先使用make_unique和make_shared创建智能指针,避免裸new,防止内存泄漏。

在C++中,shared_ptr和unique_ptr是两种常用的智能指针,用于自动管理动态分配的内存,避免内存泄漏。它们都定义在<memory>头文件中,通过RAII(资源获取即初始化)机制确保资源在对象生命周期结束时被正确释放。
unique_ptr:独占所有权的智能指针
unique_ptr表示对所指向对象的独占所有权,同一时间只能有一个unique_ptr拥有该对象。当unique_ptr被销毁或重置时,其所管理的对象也会自动被删除。
常见用法:
- 使用std::make_unique创建(C++14起支持):
#include <memory> auto ptr = std::make_unique<int>(42); // 创建一个int的unique_ptr
- 直接构造(不推荐裸new):
std::unique_ptr<int> ptr(new int(10)); // 可行但建议用make_unique
- 不能复制,但可以移动:
std::unique_ptr<int> ptr1 = std::make_unique<int>(5); // std::unique_ptr<int> ptr2 = ptr1; // 错误:不可复制 std::unique_ptr<int> ptr2 = std::move(ptr1); // 正确:转移所有权
- 通过reset()释放或重新赋值,get()获取原始指针:
ptr2.reset(); // 释放所管理的对象 ptr1.reset(new int(8)); // 重新绑定到新对象 int* raw = ptr1.get(); // 获取原始指针,不释放所有权
shared_ptr:共享所有权的智能指针
shared_ptr允许多个指针共享同一个对象,内部使用引用计数来追踪有多少个shared_ptr指向同一块内存。当最后一个shared_ptr被销毁时,对象自动被删除。
立即学习“C++免费学习笔记(深入)”;
常见用法:
- 使用std::make_shared创建(推荐方式):
auto sptr = std::make_shared<std::string>("hello");
- 多个shared_ptr可以共享同一对象:
auto sp1 = std::make_shared<int>(100); auto sp2 = sp1; // 引用计数加1 auto sp3 = sp1; // 引用计数变为3
- 引用计数可通过use_count()查看:
std::cout << sp1.use_count() << "\n"; // 输出3
- 可以用reset()减少引用计数,或置为空:
sp2.reset(); // sp2不再指向对象,计数减1
选择合适的智能指针
一般原则:
- 优先使用unique_ptr:当你只需要一个所有者时,性能更好,无额外开销。
- 使用shared_ptr:当多个部分需要共享同一个对象的生命周期时。
- 避免循环引用:两个shared_ptr互相持有对方会导致内存无法释放,可使用weak_ptr打破循环。
基本上就这些。合理使用智能指针能大幅提高代码的安全性和可维护性。









