Serj Demchenko
Serj Demchenko13. November 2019 01:32

Коллизия QEventLoop

Привет, может кто сталкивался с коллизией QEventLoop ( одна ивентлуп мешает другой) , подскажите куда копать?

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

2
Evgenii Legotckoi
  • 13. November 2019 03:16

Привет. Можно попродробнее? Вы создаёте два QEventLoop в логике своей программы? Используете мьютексы? или что?

Обычно dead lock`и исправляются только переписыванием логики программы. Но каждый случай индивидуален.

    Serj Demchenko
    • 13. November 2019 09:33
    • (bearbeitet)

    Приложение трэкинг задач. Есть вложения. Добавляем вложение и отправляем его на сервер. Для синхронного вызова методов в синхронизации, используем QEventLoop при отправке вложений. В момент синхронизации при попытке входа в задачу, показывается курсор ожидания (ожидания завершения синхронизации), для которого также используется QEventLoop . В итоге получается конфликт и QEventLoop в реализации курсора перекрывает, другой. Синхронизация не заканчивается.

    // MyModelVm.cpp
    void MyModelVm::transitionStart(int modelEntityNumber) {
        Navigator::instance().showWaitCursor("...Cинхронизация данных");
        m_currentEntity = modelEntityNumber;
    
        QEventLoop loop;
        AutoDisconnect(
            connect(&myModelManager::instance(), &myModelManager::activeSyncChanged, [this, &loop] {
    
                if ( !isActiveSync() && !isChangedLocal() ) {
                    loop.quit();
                    emit isActiveSyncChanged();
                }
            });
        )
        loop.exec();
    }
    
    
    // myModelManager.cpp
    void myModelManager::sendObjects() {
        qDebug() << "<=> sending objects";
    
        QList<QSharedPointer<LocalModel>> addedLocalModel = myModelManager::instance().getLocalAddedModel();
        qDebug() << "Number of objects added" << addedLocalModel.size();
    
        int sendObjectsCount = 0;
        int modelCount = addedLocalModel.size();
        if (sendObjectsCount) {
            QEventLoop loop;
            for (auto& localModel : addedLocalModel) {
                auto filesReply = myModelManager::instance().postFiles(ObjectHelper::filePath(localModel->fileName, localModel->fileId));
                myModelManager::instance().replyReady(filesReply,
                                                        [this, localModel, modelCount, &sendObjectsCount, &loop]
                                                        (const BaseResult& filesResult)
                {
                    if (filesResult.code() == ServiceCodeResult::OK) {
                        qDebug() << "Model" << localModel->fileName << "recieved to file-server";
                        QSharedPointer<FilesJson> jsonDataFiles = FilesJson::fromJson(filesResult.jsonDocument());
                        QString fId = jsonDataFiles->id;
                        QString fName = jsonDataFiles->fileName;
                        QString xId = StringHelper::createUuid();
                        auto postChangesModelReply = myModelManager::instance().postChangesAddModel(fName, fName, fId, xId);
                        myModelManager::instance().replyReady(postChangesModelReply,
                                                                [this, localModel, externalId, fileId, modelCount, &sendObjectsCount, &loop]
                                                                (const BaseResult& changesResult)
                        {
                            if (changesResult.code() == ServiceCodeResult::OK) {
                                qDebug() << "Attachment" << localModel->fileName << "recieved to MT Attachment";
                                m_mutex.lock(); //QMutex
                                ++sendAttachmentCount;
                                localModel->externalId = externalId;
                                localModel->fileId = fileId;
                                localModel->changeType = ChangeType::None;
                                myModelManager::instance().updateLocalModel(localModel);
    
                                if (sendObjectsCount == modeltCount) {
                                    qDebug() << "=== sendAttachmentChanges Ok";
                                    m_mutex.unlock();
                                    loop.quit();
                                    return;
                                }
                                m_mutex.unlock();
                            } else {
                                qDebug() << "Ошибка отправки файла: " + localModel->fName + " : " + changesResult.message() + " (postChangesModel)";
                                Logger::instance().write("Ошибка отправки файла: " + localModel->fName + " : " + changesResult.message(), Logger::ERROR);
                                qDebug() << "=== sendObjects Fail";
                                loop.quit();
                                return;
                            }
                        });
                    } else {
                        qDebug() << "Ошибка отправки файла: " + localModel->fName + " : " + filesResult.message() + " (postFiles)";
                        Logger::instance().write("Ошибка отправки файла: " + localModel->fName + " : " + filesResult.message(), Logger::ERROR);
                        qDebug() << "=== sendObjects Fail";
                        loop.quit();
                        return;
                    }
                });
            }
            loop.exec();
        }
    }
    

      Kommentare

      Nur autorisierte Benutzer können Kommentare posten.
      Bitte Anmelden oder Registrieren
      Letzte Kommentare
      A
      ALO1ZE19. Oktober 2024 15:19
      Fb3-Dateileser auf Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
      ИМ
      Игорь Максимов5. Oktober 2024 14:51
      Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
      d
      dblas55. Juli 2024 18:02
      QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
      k
      kmssr9. Februar 2024 02:43
      Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
      Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
      Jetzt im Forum diskutieren
      J
      JacobFib17. Oktober 2024 10:27
      добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
      JW
      Jhon Wick1. Oktober 2024 22:52
      Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
      КГ
      Кирилл Гусарев27. September 2024 16:09
      Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
      F
      Fynjy22. Juli 2024 11:15
      при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

      Folgen Sie uns in sozialen Netzwerken