在析构函数内取消引用指针时出现分段错误

时间:2018-03-10 17:44:13

标签: c++ qt destructor

我有一个头文件part.h,如下所示:

#ifndef _PART_H_
#define _PART_H_
#include <QPointer>
#include <QUrl>
class Sidebar;
class TOC;
namespace Okular
{
class OKULARPART_EXPORT Part : public KParts::ReadWritePart, public Okular::DocumentObserver, public KDocumentViewer, public Okular::ViewerInterface
{
    Q_OBJECT
    public:
        Part(QWidget* parentWidget, QObject* parent, const QVariantList& args);

        // Destructor
        ~Part();

    public:
        bool closeUrl() override;
        bool closeUrl(bool promptToSave) override;

    private:
        Sidebar * m_sidebar;
        QPointer<TOC> m_toc;
};
}
#endif

然后文件part.cpp为:

#include "part.h"
namespace Okular
{

Part::Part(QWidget *parentWidget,
QObject *parent,
const QVariantList &args)
: KParts::ReadWritePart(parent),
m_tempfile( nullptr ), m_documentOpenWithPassword( false ), m_swapInsteadOfOpening( false ), m_isReloading( false ), m_fileWasRemoved( false ), m_showMenuBarAction( nullptr ), m_showFullScreenAction( nullptr ), m_actionsSearched( false ),
m_cliPresentation(false), m_cliPrint(false), m_cliPrintAndExit(false), m_embedMode(detectEmbedMode(parentWidget, parent, args)), m_generatorGuiClient(nullptr), m_keeper( nullptr )
{
  // constructor code here

m_sidebar = new Sidebar( parentWidget );
    setWidget( m_sidebar );
}

Part::closeUrl(bool promptToSave)
{
m_sidebar->setCollapsed(promptToSave);
}

Part::~Part()
{
m_sidebar->setCollapsed(true); //segmentation fault
delete m_toc;
}
}//namespace Okular

在析构函数m_sidebar中取消引用Part::~Part时,我收到segmentation fault (core dumped)错误。 m_sidebarclass Sidebar类型的指针变量,它在sidebar.cpp中实现。 为什么我得到它,因为我认为m_sidebar不是null,因为它在Part::Part构造函数中初始化,并且它在Part::closeUrl()函数中有效。

1 个答案:

答案 0 :(得分:0)

根据手册,当您将窗口小部件传递给setWidget时,您将所有权传递给另一个窗口小部件。您不应该尝试在析构函数中访问m_sidebar

  

小部件成为滚动区域的子节点,在删除滚动区域或设置新小部件时将被销毁。

您可以订阅信号Sidebar::destroyed,并在此信号发出后重置m_sidebar = nullptr