QNetworkAccessManager“get”方法在重新启动时崩溃



我目前正在为我的应用程序添加一项功能,允许它重新启动。

这就是的主要外观

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错误。

相关内容

  • 没有找到相关文章

最新更新