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

Коллизия QEventLoop

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

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

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

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

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

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

    Serj Demchenko
    • 13 ноября 2019 г. 20: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();
        }
    }
    

      Комментарии

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

      Qt - Тест 001. Сигналы и слоты

      • Результат:84баллов,
      • Очки рейтинга4
      Ua

      Qt - Тест 001. Сигналы и слоты

      • Результат:42баллов,
      • Очки рейтинга-8
      ОК

      Qt - Тест 001. Сигналы и слоты

      • Результат:47баллов,
      • Очки рейтинга-6
      Последние комментарии
      ИМ
      Игорь Максимов22 ноября 2024 г. 21:51
      Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
      Evgenii Legotckoi
      Evgenii Legotckoi31 октября 2024 г. 23:37
      Django - Урок 064. Как написать расширение для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
      A
      ALO1ZE19 октября 2024 г. 17:19
      Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
      ИМ
      Игорь Максимов5 октября 2024 г. 16:51
      Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
      d
      dblas55 июля 2024 г. 20:02
      QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
      Сейчас обсуждают на форуме
      f
      firstlunoxod15 февраля 2025 г. 13:46
      Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
      Дмитрий
      Дмитрий3 февраля 2025 г. 16:24
      Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
      NW
      Nayo Wai30 января 2025 г. 19:22
      не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
      n
      nkly3 января 2025 г. 12:52
      Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
      M
      Marsel17 августа 2023 г. 0:26
      OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.

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