我目前正在为我的应用程序添加一项功能,允许它重新启动。
这就是的主要外观
int main(int argc, char *argv[])
{
const int RESTART_CODE = 1000;
int return_from_event_loop_code;
QPointer<QApplication> app;
QPointer<foo> main_window;
do
{
if(main_window)
delete main_window;
if(app)
delete app;
app = new QApplication(argc, argv);
main_window = new foo();
main_window->show();
app->setActiveWindow(main_window);
return_from_event_loop_code = app->exec();
}
while(return_from_event_loop_code==RESTART_CODE);
return return_from_event_loop_code;
}
现在,当使用下面提到的RestartApp
方法重新启动应用程序时,第一次运行良好。QNetworkAccessManager
的get方法返回锁定错误。这就是我的代码看起来像
void foo::MethodA()
{
....
....
QUrl url("some url");
QNetworkRequest request;
request.setUrl(url);
networkManager = new QNetworkAccessManager(this);
QObject::connect(networkManager, SIGNAL(finished(QNetworkReply*)),this, SLOT(replyFinished(QNetworkReply*)),static_cast<Qt::ConnectionType>(Qt::QueuedConnection | Qt::UniqueConnection));
currentReply = networkManager->get(request); //Crashes when the app is restarted again
connect(currentReply, SIGNAL(error(QNetworkReply::NetworkError)),this, SLOT(slotNetworkError(QNetworkReply::NetworkError)),Qt::UniqueConnection);
}
//Slot
void foo::replyFinished(QNetworkReply* rply)
{
....
.....
rply->deleteLater();
}
//Slot
void foo::RestartApp()
{
QCoreApplication::exit(1000);
}
现在,当应用程序第一次启动时会发生什么,一切都很好。但是,当调用RestartApp方法,并且在MethodA中的语句currentReply = networkManager->get(request);
中再次调用main中的return_from_event_loop_code = app->exec();
方法时,应用程序崩溃并最终进入
mlock.c
void __cdecl _unlock (
int locknum
)
{
/*
* leave the critical section.
*/
LeaveCriticalSection( _locktable[locknum].lock );
}
知道为什么当应用程序被指示重新启动时,应用程序会在QNetworkAccessManager的get语句中崩溃吗?
我已经对坠机事件进行了一些调查。它确实是由QApplication
的破坏引起的。QNetworkAccessManager
在内部使用QNetworkConfigurationManagerPrivate
对象。此对象在需要时创建,并一直使用到应用程序完成。qNetworkConfigurationManagerPrivate
函数用于创建或获取现有对象。
当QApplication
被破坏时,它执行所有的后例程,包括connManager_cleanup
。此函数间接破坏QNetworkConfigurationManagerPrivate
对象并设置appShutdown
本地标志。设置此标志后,qNetworkConfigurationManagerPrivate
函数将不再创建新的QNetworkConfigurationManagerPrivate
对象。因此CCD_ 15被破坏后,CCD_。
我认为这是对QApplication
对象的滥用,但最近我发现了一个使用正确的证明链接。
Qt的编码惯例规定:
Q[Core]应用程序是一个单例类。一次只能有一个实例。但是,可以销毁该实例并创建一个新实例。
所以这个问题应该被认为是一个Qt错误。