【发布时间】:2018-08-19 02:36:45
【问题描述】:
我有一个头文件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() 函数中工作。
【问题讨论】:
标签: c++ qt destructor