QWaitCondition
文中讲解(翻译)了使用waitcondition的在QT docs中一个例子。
QWaitCondition 允许线程在某些情况发生时唤醒另外的线程。一个或多个线程可以阻塞等待一QWaitCondition ,用wakeOne()或wakeAll()设置一个条件。wakeOne()随机唤醒一个,wakeAll()唤醒所有。
阅读qt docs会发现在QWaitCondition的类介绍中找到类似的介绍,基本步骤是这样的
forever {
mutex.lock();
keyPressed.wait(&mutex);
++count;
mutex.unlock();
do_something();
mutex.lock();
--count;
mutex.unlock();
}
这样做的目的是如果存在多个线程等在同一个condition,使用
forever {
mutex.lock();
keyPressed.wait(&mutex);
do_something();
mutex.unlock();
}
这段代码会出现2个问题一个是线程唤醒的次序不定,其次是如果某个(些)线程PC在do_something()
里边,那么会导致他(们)不会被唤醒。因此所以把do_something();
放在了 外边,另外增加一个计数器来保证条件被响应。
所以激活条件的线程需要:
forever {
getchar();
mutex.lock();
// Sleep until there are no busy worker threads
while (count > 0) {
mutex.unlock();
sleep(1);
mutex.lock();
}
keyPressed.wakeAll();
mutex.unlock();
}
主线程中首先穿件QThread(继承)类对象,其次使用thread.start(),启动线程,如果主程序没有其他操作,需要避免主程序返回,可以使用thread.wait();
。
另外在thread.start()
中会调用run()
函数,系统会根据优先级管理线程,同时在run()
被调用之前会释放started()
信号。
相关:
QThread使用方法总结
文章主要介绍了在多线程中信号和槽的使用方法。他指出了一种使用派生qObject类的方法,不必显示的使用connect函数,
多线程程序设计
文章介绍很全面,同步等等很好很详细。
QThread 与 QObject的关系