shared_ptr的引用计数线程安全,但对象访问和变量读写需外部同步。正确做法是用互斥锁保护shared_ptr变量本身,对所指对象的操作需额外加锁,避免循环引用可使用weak_ptr。

在多线程环境下使用C++的
std::shared_ptr
C++标准规定:
shared_ptr
shared_ptr
简单说:引用计数安全,指针对象访问不安全,shared_ptr变量本身也不是线程安全的容器。
假设我们有一个全局的
shared_ptr<Data>
立即学习“C++免费学习笔记(深入)”;
std::shared_ptr<Data> global_data;
错误用法:
global_data = std::make_shared<Data>();
auto p = global_data;
这两个操作同时修改和读取同一个
global_data
正确做法: 使用互斥锁保护对shared_ptr变量的访问:
std::mutex data_mutex;
std::shared_ptr<Data> global_data;
// 线程安全地更新
void update_data() {
auto new_data = std::make_shared<Data>();
std::lock_guard<std::mutex> lock(data_mutex);
global_data = new_data;
}
// 线程安全地读取
std::shared_ptr<Data> get_data() {
std::lock_guard<std::mutex> lock(data_mutex);
return global_data; // 拷贝是安全的
}
注意:返回的是副本,调用方拿到后可以在自己线程中使用,引用计数已增加,生命周期得到保障。
即使多个线程各自持有一个指向同一对象的
shared_ptr
shared_ptr<Data>
data->modify()
modify
Data
典型模式:
class Data {
public:
void modify() {
std::lock_guard<std::mutex> lock(mutex_);
// 实际修改操作
}
private:
mutable std::mutex mutex_;
};
多线程中频繁创建对象容易引入循环引用。应合理使用
std::weak_ptr
weak_ptr
lock()
shared_ptr
示例:
std::weak_ptr<Data> cache;
auto ptr = cache.lock();
if (ptr) {
// 安全使用ptr,引用计数已增加
use(ptr);
} else {
// 对象已被释放
}
基本上就这些。只要记住:shared_ptr帮你管生命周期,不管并发访问。变量共享要加锁,对象访问也要加锁。设计清晰,责任分明,多线程下才能安全使用。
以上就是C++shared_ptr在多线程环境下安全使用的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号