因此,我已经使用了QtConcurrent::run一段时间了,它非常棒。但是现在我需要这个函数来返回一个对象。因此,我使用伪代码
QFutureWatcher<MyObject> fw;
QFuture<MyObject> t1 = QtConcurrent::run(&thOb, &MythreadObjFunc::getList, ConSettings, form, query);
fw.setFuture(t1);
// Both .results() and waitForFinished() block
fw.waitForFinished();
MyObject entries = t1.result();然后,我遍历myObject。问题是,这是阻塞的,例如,我的主要GUI没有响应。这就是我开始使用QtConcurrent::run的全部原因。
因此,建议让我的GUI执行QtConcurrent::run并获得对象返回而不是块的方法是什么?我想到了信号和插槽,其中信号将来自QtConcurrent::run,但这意味着它将来自另一个线程,并且我阅读了不推荐的内容。
耽误您时间,实在对不起。
发布于 2014-08-19 21:35:27
在QtConcurrent::run()中,您不能发出任何信号。可运行函数不是QObject。这是第一件事。
另一件事是,QFutureWatcher::waitForFinished()阻止执行,直到线程结束其执行为止。这就是我们想要的行为。如果要等待函数完成,为什么还要在单独的线程上启动它呢?这没有任何意义。
最简单的解决方案是使您的函数成为QObject继承类的成员,将实例移动到另一个线程,启动计算并发出done()信号。Qt的信号和插槽系统是线程安全的,是使用它的最佳方式。Qt提供了一个出色的文档,涵盖了这个主题。你应该从这里开始读:http://qt-project.org/doc/qt-4.8/threads.html
发布于 2014-08-20 00:12:21
您不应该在GUI线程中使用任何waitForFinished函数。相反,将一个插槽连接到未来观察者的finished信号。有关示例,请参见this answer。
https://stackoverflow.com/questions/25393144
复制相似问题