std::shared_ptr of "this" 难题
在智能指针领域,你可能会遇到这样的场景:一个类的对象A,父级,需要与其子级(B 类的对象)共享对自身的引用。但是,传递一个简单的指针到“this”可能会导致无意义的错误。
解决方案在于神秘的std::enable_shared_from_this 工具。从此类继承使您能够在类中访问 .shared_from_this(),从而授予您当前对象的共享所有权。
然而,这种互连性出现了一个重要的警告:循环依赖的可能性。为了避免资源泄漏的陷阱,明智的做法是在创建此类依赖项时引入 std::weak_ptr。
采用这种修改后的方法,修改后的代码可能类似于以下内容:
<code class="cpp">class A : public std::enable_shared_from_this<A> { public: void addChild(std::shared_ptr<B> child) { children.push_back(child); child->setParent(shared_from_this()); // Corrected reference passing } private: std::list<std::weak_ptr<B>> children; // Using weak_ptr to prevent circular references }; class B { public: void setParent(std::shared_ptr<A> parent) { this->parent = parent; } private: std::shared_ptr<A> parent; };</code>
请记住,调用 .shared_from_this() 需要在调用时 std::shared_ptr 拥有该对象的所有权。这消除了堆栈分配对象的可能性,并且通常限制从构造函数或析构函数中调用 .shared_from_this()。
以上是如何使用'std::shared_ptr”安全地与子对象共享对'this”的引用?的详细内容。更多信息请关注PHP中文网其他相关文章!