我有一个头文件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_sidebar
是class Sidebar
类型的指针变量,它在sidebar.cpp
中实现。
为什么我得到它,因为我认为m_sidebar
不是null,因为它在Part::Part
构造函数中初始化,并且它在Part::closeUrl()
函数中有效。
答案 0 :(得分:0)
根据手册,当您将窗口小部件传递给setWidget
时,您将所有权传递给另一个窗口小部件。您不应该尝试在析构函数中访问m_sidebar
。
小部件成为滚动区域的子节点,在删除滚动区域或设置新小部件时将被销毁。
您可以订阅信号Sidebar::destroyed
,并在此信号发出后重置m_sidebar = nullptr
。