我有一个头文件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
在析构函数Part::~Part
内取消引用m_sidebar
时,我收到segmentation fault (core dumped)
错误。 m_sidebar
是 class Sidebar
类型的指针变量,在 sidebar.cpp
中实现。为什么我得到它,因为我认为m_sidebar
不是空的,因为它是在构造函数中初始化Part::Part
并且它Part::closeUrl()
函数中工作。
根据手册,当您将小部件传递给setWidget
时,您将所有权传递给另一个小部件。不应尝试访问析构函数中的m_sidebar
。
小部件将成为滚动区域的子项,并在删除滚动区域或设置新小部件时销毁。
您可以订阅信号Sidebar::destroyed
并在此信号发出时重置m_sidebar = nullptr
。