Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: QMutex. Принудительная блокировка для ожидания команды
Форум на CrossPlatform.RU > Библиотеки > Qt > Qt Общие вопросы
MishaUA
Здравствуйте!
Есть 2 потока. Первый Занимается обработкой данных, а второй дает команду на запуск, выглядит примерно вот так:
QMutex m;
// Поток 1:
while(1) {
m.unlock();
// блокируем поток, его должен разбудить другой поток, если не разбудит, то он проснется сам по истечению 5с.
m.lock();
m.tryLock(5000);
// выполняем действия
}

// Поток 2:
void func() {
m.unlock();
}

Правильный ли данный подход? Просто у меня почему-то в m.tryLock(5000) замирает и по истечению 5с не просыпается.
Алексей1153
MishaUA, нет, не правильный подход в корне

ты считаешь, что можно включить блок в одном потоке и отключить его во втором. Это не так. Каждый поток вызывает собственную пару lock-unlock, а система обеспечивает, что эти два "блока" не пересекутся во время выполнения кода обоих потоков

в твоём случае можно suspend второй поток. И в первом потоке запускать второй по некоему отсчёту времени

и вот так наизнанку никогда не делай

while(1) {
m.unlock();

m.lock();
}


Строго в порядке

Цитата
m.lock();
m.unlock();


Для этого есть специальный класс QMutexLocker. Пример:

//начало синхронизируемого блока
{
   QMutexLocker locker(&m);

   //синхронизируемый код

}
Iron Bug
вообще, для того, что вы тут пытаетесь сделать, в плюсах есть condition variables. плюс вероятно, что будет введён barrier, который специально под такие случаи заточен.
не знаю, есть ли какие-то обёртки в Qt, но можно просто взять обычные плюсовые средства синхронизации.
Алексей1153
похоже, что QWaitCondition делает что-то подобное
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Форум IP.Board © 2001-2022 IPS, Inc.