Serj Demchenko
Serj Demchenko13 листопада 2019 р. 01:32

Коллизия QEventLoop

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

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

Вам це подобається? Поділіться в соціальних мережах!

2
Evgenii Legotckoi
  • 13 листопада 2019 р. 03:16

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

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

    Serj Demchenko
    • 13 листопада 2019 р. 09: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();
        }
    }
    

      Коментарі

      Only authorized users can post comments.
      Please, Log in or Sign up
      AD

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

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

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

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

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

      • Результат:20бали,
      • Рейтинг балів-10
      Останні коментарі
      ИМ
      Игорь Максимов22 листопада 2024 р. 11:51
      Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
      Evgenii Legotckoi
      Evgenii Legotckoi31 жовтня 2024 р. 14:37
      Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
      A
      ALO1ZE19 жовтня 2024 р. 08:19
      Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
      ИМ
      Игорь Максимов05 жовтня 2024 р. 07:51
      Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
      d
      dblas505 липня 2024 р. 11:02
      QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
      Тепер обговоріть на форумі
      Evgenii Legotckoi
      Evgenii Legotckoi24 червня 2024 р. 15:11
      добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
      t
      tonypeachey115 листопада 2024 р. 06:04
      google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
      NSProject
      NSProject04 червня 2022 р. 03:49
      Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
      9
      9Anonim25 жовтня 2024 р. 09:10
      Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

      Слідкуйте за нами в соціальних мережах