Serj Demchenko
Serj Demchenko13 ноября 2019 г. 1:32

Коллизия QEventLoop

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

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

2
Evgenii Legotckoi
  • 13 ноября 2019 г. 3:16

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

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

    Serj Demchenko
    • 13 ноября 2019 г. 9:33
    • (ред.)

    Приложение трэкинг задач. Есть вложения. Добавляем вложение и отправляем его на сервер. Для синхронного вызова методов в синхронизации, используем 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();
        }
    }
    

      Комментарии

      Только авторизованные пользователи могут публиковать комментарии.
      Пожалуйста, авторизуйтесь или зарегистрируйтесь
      AD

      C++ - Тест 004. Указатели, Массивы и Циклы

      • Результат:50баллов,
      • Очки рейтинга-4
      m
      • molni99
      • 26 октября 2024 г. 1:37

      C++ - Тест 004. Указатели, Массивы и Циклы

      • Результат:80баллов,
      • Очки рейтинга4
      m
      • molni99
      • 26 октября 2024 г. 1:29

      C++ - Тест 004. Указатели, Массивы и Циклы

      • Результат:20баллов,
      • Очки рейтинга-10
      Последние комментарии
      i
      innorwall14 ноября 2024 г. 21:26
      Qt/C++ - Урок 031. QCustomPlot - строим график по времени buy generic priligy We can just chat, and we will not lose too much time anyway
      i
      innorwall14 ноября 2024 г. 19:03
      Qt/C++ - Урок 060. Настройка внешнего вида приложения в рантайме I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
      i
      innorwall14 ноября 2024 г. 11:42
      Как Копировать Файлы в Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
      i
      innorwall14 ноября 2024 г. 9:09
      Qt/C++ - Урок 068. Hello World с использованием системы сборки CMAKE в CLion ditropan pristiq dosing With the Yankees leading, 4 3, Rivera jogged in from the bullpen to a standing ovation as he prepared for his final appearance in Chicago buy priligy pakistan
      Сейчас обсуждают на форуме
      i
      innorwall14 ноября 2024 г. 3:39
      добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
      i
      innorwall11 ноября 2024 г. 10:55
      Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
      9
      9Anonim25 октября 2024 г. 9:10
      Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
      ИМ
      Игорь Максимов3 октября 2024 г. 4:05
      Реализация навигации по разделам Спасибо Евгений!

      Следите за нами в социальных сетях