5

我正在考虑在我的 qt 工作中开始使用智能指针。让我感到困惑的是智能指针如何与 Qt 垃圾收集一起使用。整个 Qt 都遵循子 QObject 以 QObject* parent 作为 ctor 参数构造的习语,因此可以进行垃圾收集。例如:

     QWidget* mWidget = new QWidget(this);//Here we not only 
                                          //ensure that mWidget will be deleted  
                                          //when its parent is deleted, but also tell qt,  
                                          //that mWidget is not a window, but belongs to 
                                          //parent's layout         

现在,如果我想将 mWidget 包装到智能指针中。

 typedef QScopedPointer<QWidget> WidgPtr;
 WidgPtr mWidget = WidgPtr(new QWidget(this));

但是现在当调用 parent 的 dtor 时,它会在 mWidget 的指针上调用 delete 两次。首先是由于垃圾收集,其次是调用智能指针 dtor。

当然我们可以在没有父级的情况下构造mWidget,然后改变一些标志来关闭窗口行为或调用setParent()(但是mWidget又会被删除两次)。但对我来说,做如此复杂的初始化只是为了能够使用智能指针而不是原始指针,这太过分了。或者我想念什么?谢谢。

4

1 回答 1

5

QScopedPointer并且QSharedPointer不知道他们的目标对象是生存还是死亡,因此如果您将智能指针保留在成员变量之间以外的任何其他位置,那么是的,在您的情况下,析构函数可能会被调用两次。这就是为什么这些类型的智能指针非常不适合QObjects(但是当您的对象没有父对象时它们仍然很有用)。

如果您需要保留指向 的受保护指针QObject,请使用QPointer: 一旦对象被销毁,它将变为 null,因此您可以随时delete使用它,而不必担心造成任何混乱。但请记住,这QPointer不会破坏析构函数中的引用对象。在大多数情况下,您应该建立层次结构QObjects并让所有权系统清理内存。

于 2012-10-13T08:50:05.607 回答