c++++中的智能指针unique_ptr和shared_ptr用于自动管理动态内存,避免内存泄漏。unique_ptr适用于独占资源管理,不可复制但可移动,适合局部对象、工厂函数返回值等场景;shared_ptr通过引用计数实现资源共享,适合多线程或模块间共享对象的场景。二者相比,unique_ptr性能开销低,shared_ptr因维护引用计数代价稍高,必要时可配合weak_ptr解决循环引用问题。

C++中的智能指针是管理动态内存的重要工具,unique_ptr和shared_ptr是最常用的两种。它们能帮助我们自动释放资源,避免内存泄漏,同时也能提升代码的可读性和安全性。

下面我们就来看看这两个智能指针怎么用,以及各自适合什么场景。
unique_ptr:独占式资源管理unique_ptr代表的是对资源的唯一拥有权。也就是说,同一时间只能有一个unique_ptr指向某个对象,它不能被复制(copy),但可以转移所有权(move)。
立即学习“C++免费学习笔记(深入)”;

std::unique_ptr<int> ptr(new int(10)); // 或者更推荐的方式: auto ptr = std::make_unique<int>(10);
如果你尝试复制,编译器会报错:
auto ptr2 = ptr; // 编译错误!无法复制 unique_ptr
但可以通过移动语义转移所有权:

auto ptr2 = std::move(ptr); // 合法,ptr现在为空
unique_ptr,调用方拿到后自动管理生命周期。unique_ptr代替new/delete,避免忘记释放。举个例子,假设你有个类专门负责日志记录:
class Logger {
public:
static std::unique_ptr<Logger> create() {
return std::make_unique<Logger>();
}
private:
Logger() {}
};这样别人拿到的就是一个独占的Logger实例,清晰又安全。
shared_ptr:共享式资源管理shared_ptr则是通过引用计数来管理资源的,多个shared_ptr可以指向同一个对象,当最后一个指向它的指针销毁时,资源才会被释放。
std::shared_ptr<int> ptr1 = std::make_shared<int>(20); std::shared_ptr<int> ptr2 = ptr1; // 合法,引用计数+1
每个shared_ptr背后有两个指针:
所以每次复制shared_ptr都会更新引用计数,析构时减少计数,为0就释放资源。
weak_ptr配合解决循环引用问题。举个简单例子:
auto data = std::make_shared<std::vector<int>>(10, 0);
std::thread t1([data]() {
for (int i = 0; i < data->size(); ++i)
(*data)[i] += 1;
});
std::thread t2([data]() {
for (int i = 0; i < data->size(); ++i)
(*data)[i] += 2;
});两个线程都持有data的共享指针,主线程等待结束后,data才会被释放。
unique_ptr vs shared_ptr
这其实是个很常见的问题,总结一下几个判断依据:
unique_ptr
shared_ptr
weak_ptr
另外要注意的一点是性能开销:
unique_ptr几乎没有额外开销,效率高shared_ptr因为要维护引用计数和控制块,内存和性能代价稍大基本上就这些了。unique_ptr和shared_ptr各有各的用途,合理使用可以让你的代码既安全又简洁。别忘了还有weak_ptr,它能在某些复杂场景下帮你避免循环引用的问题。
以上就是C++智能指针怎么使用 unique_ptr shared_ptr应用场景的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号