析构函数上的Segfault
Segfault on destructor
当我关闭应用程序并且析构函数为这个类运行时,seg错误让我感到沮丧。
vlocationdropdowns.h:
#include <QWidget>
class VLocationDropDowns : public QWidget
{
Q_OBJECT
public:
VLocationDropDowns(QString activeText, QWidget *parent = 0);
~VLocationDropDowns();
};
vlocationdropdown.cpp:
VLocationDropDowns::VLocationDropDowns(QString activeText, QWidget *parent) :
QWidget()//I've also had this as QWidget(parent, Qt::Widget)
{
}
VLocationDropDowns::~VLocationDropDowns()
{
}
我已经在另一个类的构造函数中创建了这个类的对象(locationLineEdit是一个指针)(也许我应该说这个类也继承了QWidget):
locationDropDowns = new VLocationDropDowns(randomString, this);
但是当该类的析构函数运行delete locationDropDowns;
时,我得到一个segfault。
我是管理记忆的新手,所以我意识到这可能是一个棘手的问题,但我现在已经把它搞砸了。我已经把我能写的所有内容都评论掉了vlocationdropdown.cpp,它仍然是seg断层,所以我现在不知道。是什么原因造成的?
我会按照以下顺序尝试一些建议:
- 代码看起来没有错。尝试干净的构建
- 在析构函数中放入一个printf,看看它是否被调用
- 隔离到一个小程序,只做新的和删除
- 尝试不使用
Q_OBJECT
- 以同样的方式,尝试单独创建和删除
QWidget
- 为什么不使用传递到构造函数中的参数
相关文章:
- 什么时候调用组成单元对象的析构函数
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 内联映射初始化的动态atexit析构函数崩溃
- 什么时候调用析构函数
- 优先顺序:智能指针和类析构函数
- C++-明确何时以及如何调用析构函数
- 使用基类指针创建对象时,缺少派生类析构函数
- 在c++中使用向量时,如何调用构造函数和析构函数
- 重载运算符new[]的行为取决于析构函数
- 我需要知道编译器如何在cpp中使用析构函数
- 为什么在使用转换构造函数赋值后调用C++类的析构函数?
- 析构函数调用
- 通过引用传递-为什么要调用这个析构函数
- 对具有动态分配的内存和析构函数的类对象的引用
- 重载 -> shared_ptr 个实例中的箭头运算符<interface>,接口中没有纯虚拟析构函数
- 导致SegFault C++的析构函数
- 类析构函数 SEGFAULT
- std::函数析构函数中的Segfault
- 析构函数上的Segfault
- 在析构函数中释放内存时出现segfault