Очистка должна выполняться деструкторами и дочерними родителями.
Сделайте ваш главный объект (главный объект) дочерним по отношению к QApplication, чтобы он был уничтожен всеми своими дочерними объектами до появления QApplication.
Ты уверен, что убил все свои темы? Если это поток с eventloop, обязательно вызовите QThread::quit()
для выхода из Eventloop перед вызовом QThread::wait()
Вы также можете использовать пустоту QApplication::qAddPostRoutine ( QtCleanUpFunction ptr )
сделать специальную уборку.
Для отладки этих сообщений вы можете использовать QtMsgHandler qInstallMsgHandler ( QtMsgHandler h )
и написать свой собственный обработчик сообщений для сбора этих предупреждений. Если вы можете смоделировать проблему, вы можете установить точку останова для сообщения и посмотреть в стеке, откуда приходит сообщение.
void debugMessageHandler( QtMsgType type, const char *msg ){
if(QString(msg).contains( "The message you can see in the console" )){
int breakPointOnThisLine(0);
}
switch ( type ) {
case QtDebugMsg:
fprintf( stderr, "Debug: %s\n", msg );
break;
case QtWarningMsg:
fprintf( stderr, "Warning: %s\n", msg );
break;
case QtFatalMsg:
fprintf( stderr, "Fatal: %s\n", msg );
abort();
}
}
Для очистки с помощью деструктора и дочернего родительского корабля вы можете поймать сигнал закрытия консоли и вызвать QCoreApplication::exit()
к экземпляру приложения.
#include <csignal>
#include <QtCore/QCoreApplication>
using namespace std;
struct CleanExit{
CleanExit() {
signal(SIGINT, &CleanExit::exitQt);
signal(SIGTERM, &CleanExit::exitQt);
signal(SIGBREAK, &CleanExit::exitQt) ;
}
static void exitQt(int sig) {
QCoreApplication::exit(0);
}
};
int main(int argc, char *argv[])
{
CleanExit cleanExit;
QCoreApplication a(argc, argv);
return a.exec();
}