如果我尝试直接使用quit()方法,它可以很好地编译,但是在运行时会出现一个错误:"Object::connect: No slot myClass::quit()“。那么,为了避免这种情况,有没有办法呢?通过使用方法quitPicture()(定义为插槽),应用程序可以很好地工作。这是唯一的解决方案吗?
myClass::myClass(QWidget *parent)
: QWidget(parent)
{
QWidget *window = new QWidget;
window->setWindowTitle(QObject::tr("Class"));
QPushButton *quitButton = new QPushButton("&Quit");
// QObject::connect(quitButton, SIGNAL(clicked()), this, SLOT(quit())); //showing run time error
QObject::connect(quitButton, SIGNAL(clicked()), this, SLOT(quitPicture())); //working perfectly
QHBoxLayout *layout = new QHBoxLayout;
layout->addWidget(this);
layout->addWidget(quitButton);
window->setLayout(layout);
window->show();
}
void myClass::quitPicture()
{
std::cout << "calling quitPicture" << std::endl;
QApplication::quit();
}发布于 2013-02-23 21:32:26
按钮的clicked信号可以直接连接到应用程序的quit插槽:
QObject::connect(quitButton, SIGNAL(clicked()),
QApplication::instance(), SLOT(quit()));发布于 2016-05-12 08:51:21
这个答案涵盖了Qt中新的信号/槽语法,另外还涵盖了在使用使用重载的信号时如何处理它。
对于没有过载的信号,使用QObject作为示例对象:
QObject obj(nullptr);
QObject::connect(&obj, &QObject::destroyed, QCoreApplication::instance(), \
&QCoreApplication::quit);对于使用QProcess作为示例对象的重载信号:
QProcess * process = new QProcess(QCoreApplication::instance());
QObject::connect(process, static_cast<void (QProcess::*)(int)>(&QProcess::finished), \
QCoreApplication::instance(), &QCoreApplication::quit); 这个看起来很疯狂的语法基本上是这样的,就像占位符语法:
static_cast< _signalReturnType_( _ObjectName::*_ )( _overloadType1_, _overloadType2_, \
…etc )>( _&ObjectName::signalName_ )如果你想了解更多关于原因的细节,你可以查看this link。
由于QProcess有两个重载,这是它的另一个重载:
QProcess * process = new QProcess(QCoreApplication::instance());
QObject::connect(process, static_cast<void (QProcess::*)(int, QProcess::ExitStatus)>( \
&QProcess::finished ), QCoreApplication::instance(), &QCoreApplication::quit);如果这些看起来很疯狂的东西让你头晕目眩,别担心。你可以在这里评论问题,因为我通常每天都会检查,至少现在是这样。
发布于 2017-04-01 02:08:15
void my_exit_func()
{
// in mainwindow.cpp
delete MainWindow;
}https://stackoverflow.com/questions/15040988
复制相似问题