答案:weak_ptr通过弱引用打破shared_ptr的循环引用,避免内存泄漏。在相互引用场景中,将一端改为weak_ptr,使引用计数不增,对象可正常释放;访问时需用lock()获取临时shared_ptr。

在C++中,shared_ptr 是一种智能指针,通过引用计数自动管理对象生命周期。当多个 shared_ptr 指向同一个对象时,引用计数增加;只有当所有指向该对象的 shared_ptr 都被销毁或重置后,对象才会被释放。但这种机制存在一个问题:循环引用。
循环引用导致内存泄漏
当两个或多个对象通过 shared_ptr 相互持有对方时,引用计数永远无法降为0,即使这些对象已经不再被外部使用,也无法被释放。
例如:
class B;class A {
public:
std::shared_ptr ptr_b;
~A() { std::cout };
class B {
public:
std::shared_ptr ptr_a;
~B() { std::cout };
int main() {
auto a = std::make_shared();
auto b = std::make_shared();
a->ptr_b = b;
b->ptr_a = a;
return 0;
}
这段代码中,A 持有 B 的 shared_ptr,B 也持有 A 的 shared_ptr。main 函数结束时,a 和 b 离开作用域,引用计数减1,但由于彼此仍相互引用,引用计数不会归零,A 和 B 都不会被析构,造成内存泄漏。
立即学习“C++免费学习笔记(深入)”;
weak_ptr 解决循环引用问题
weak_ptr 是一种弱引用指针,它不增加对象的引用计数。它可以指向一个由 shared_ptr 管理的对象,但不会影响其生命周期。weak_ptr 常用于打破 shared_ptr 的循环引用。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~