在c++中,使用unique_ptr的场景包括:1.资源只能由一个对象管理时,2.在容器中存储不确定生命周期的对象时,3.工厂函数返回值中使用时,4.需要支持多态但不想共享所有权时。1.当资源需独占时,unique_ptr防止复制并确保自动释放;2.容器存储时绑定生命周期,避免内存风险;3.工厂函数返回时明确所有权转移,无需手动delete;4.可指向派生类实现多态,且无引用计数开销。若需共享资源或仅观察状态,则应选用shared_ptr或weak_ptr。

在C++中,当你需要确保某个资源(通常是动态分配的内存)只能被一个指针拥有,并且希望在不再使用时自动释放,unique_ptr就是最佳选择。它适用于“独占所有权”的场景,也就是说,资源只能由一个指针管理,不能共享。

1. 资源只能由一个对象管理时
这是使用
unique_ptr最直接的理由。如果你设计的对象不应该复制、只允许移动,那么用
unique_ptr可以自然表达这种语义。

- 比如:一个类内部持有一个文件句柄或网络连接的封装对象,你不希望这个资源被复制,而是随着类实例的销毁而释放。
unique_ptr
能防止意外复制,编译器会报错,避免潜在的资源泄漏。
例子:
立即学习“C++免费学习笔记(深入)”;
class Logger {
std::unique_ptr<FileHandler> file_;
public:
Logger(std::unique_ptr<FileHandler> f) : file_(std::move(f)) {}
};这里你必须用
std::move传递资源,明确表示所有权转移。

2. 在容器中存储不确定生命周期的对象
当你想在容器(如
vector、
map)中保存一些对象,但这些对象的生命周期和容器本身绑定,并且不需要共享所有权时,
unique_ptr是理想选择。
- 容器负责对象的释放,不会遗漏。
- 避免裸指针带来的内存管理风险。
例如:
std::vector<std::unique_ptr<Task>> tasks;
tasks.push_back(std::make_unique<DownloadTask>("file.zip"));这样每个任务只属于这个容器,离开容器作用域时自动清理。
3. 工厂函数返回值中使用unique_ptr
工厂函数用于创建对象并返回,通常不希望调用者复制返回的对象。此时返回
unique_ptr是最清晰的做法。
- 表达“我创建了它,现在归你管”的语义。
- 避免手动delete,减少内存泄漏风险。
示例:
std::unique_ptr<Shape> createShape(ShapeType type) {
if (type == ShapeType::Circle)
return std::make_unique<Circle>();
else
return std::make_unique<Square>();
}调用者拿到的是唯一拥有权,处理起来安全又方便。
4. 需要支持多态但不想共享所有权时
unique_ptr可以指向派生类对象,并在其析构时正确调用虚析构函数,非常适合用来实现多态行为,同时保持独占性。
- 不像
shared_ptr
那样引入引用计数开销。 - 更适合局部对象或单线程中使用的多态结构。
比如:
std::unique_ptr<Animal> pet = std::make_unique<Dog>(); pet->speak(); // 多态调用
只要你不打算把
pet传给其他对象长期持有,就非常适合用
unique_ptr。
小贴士:什么时候不该用?
- 如果你需要多个指针共享同一个资源,应该用
shared_ptr
。 - 如果只是观察资源是否还存在,不要求所有权控制,可以用普通指针或
weak_ptr
。
总的来说,当你希望资源只有一个主人、生命周期明确、自动释放且不允许共享时,unique_ptr 是首选工具。合理使用可以让代码更简洁、更安全,也能帮助团队成员理解设计意图。
基本上就这些。










