循环引用指两个对象通过shared_ptr相互持有,导致内存泄漏;解决方法是用weak_ptr打破循环,避免引用计数无法归零。

在C++11中使用
std::shared_ptr
std::shared_ptr
std::weak_ptr
假设类A持有一个指向B的
std::shared_ptr
std::shared_ptr
#include <memory>
struct B;
struct A {
std::shared_ptr<B> ptr;
~A() { std::cout << "A destroyed\n"; }
};
struct B {
std::shared_ptr<A> ptr;
~B() { std::cout << "B destroyed\n"; }
};
如果创建两个对象并互相赋值:
auto a = std::make_shared<A>(); auto b = std::make_shared<B>(); a->ptr = b; b->ptr = a;
此时,a和b的引用计数都为2。离开作用域后,
shared_ptr
立即学习“C++免费学习笔记(深入)”;
将其中一个方向的
shared_ptr
weak_ptr
struct B;
struct A {
std::shared_ptr<B> ptr;
~A() { std::cout << "A destroyed\n"; }
};
struct B {
std::weak_ptr<A> ptr; // 改为 weak_ptr
~B() { std::cout << "B destroyed\n"; }
};
此时,B持有的是指向A的弱引用,不会增加A的引用计数。当外部的
shared_ptr<A>
访问
weak_ptr
if (auto locked = b.ptr.lock()) {
// 使用 locked 操作 A 的对象
} else {
// 对象已被释放
}
在设计对象关系时,明确“所有权”关系:
shared_ptr
weak_ptr
shared_ptr
weak_ptr
weak_ptr
基本上就这些。只要在可能形成闭环的地方引入
weak_ptr
以上就是C++11如何使用std::shared_ptr循环引用解决的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号