Qt 如何处理耗时的线程,不影响主线程响应 QApplication::processEvents)
原创
©著作权归作者所有:来自51CTO博客作者jacklicto的原创作品,请联系作者获取转载授权,否则将追究法律责任
事件原因:
前些时间遇到一个问题,在主线程接收子线程读的数据,一直接收不到,但放在子线程没有问题;
后面查了一下,因为接收子线程使用了 qApp->processEvents();
查了一下 qApp->processEvents(); 用处;会优先响应主线程(UI线程) ;防止UI线程卡顿;
查了一下主要有两个作用:
- 可做延时函数
QCoreApplication::ProcessEvents(QEventLoop::AllEvents, 50);
- 在处理需要长时间的操作时,为了保持界面响应
在复杂操作的过程中频繁调用QApplication::processEvents();
如使用线程读数据,同时保证界面响应:
while (!isRunning) {
doWork();
qApp->processEvents();
}
还有一种应用场景:
处理一些跟界面无关的但耗时的事情,这些事情跟界面在同一个线程中,由于时间太长,导致界面无法响应,处于“假死”状态。
在这种情况下,有一种方法是使用多线程,即在子线程中处理文件保存;
最简单的办法就是在文件保存过程中频繁调用QApplication::processEvents()。
该函数的作用是让程序处理那些还没有处理的事件,然后再把使用权返回给调用者。
bool writeFile(const QString &filename)
{
QFile file(filename);
int rowCount=100;
QApplication::setOverrideCursor(Qt::WaitCursor);
for(int r = 0; r != rowCount; ++r)
{
for(int c = 0; c != colCount; ++c)
{
//writefile ;
qApp.processEvents();
}
}
QApplication::restoreOverrideCursor();
}