1. 经验
使用QtConcurrent::run()
来运行自定义类的成员函数时一定要确保自定义类继承了QObject
,不然线程池的初始化会有问题。
2. 教训
当我启动非QObject
的成员函数时出现的问题真实让人摸不着头脑,见识到量子力学的既视感:
3. 原因分析
QtConcurrent::run
有两种输入方式:
// 1
QFuture<T> QtConcurrent::run(Function function, ...)
// 2
QFuture<T> QtConcurrent::run(QThreadPool *pool, Function function, ...)
第一种输入等同于使用了公共线程池:
QtConcurrent::run(QThreadPool::globalInstance(), function, ...);
但是这一种用法似乎只适用于外部函数,对于如果用以启动成员函数会报错。
也就是说要用以启动类成员函数不能使用第一种方式。
在使用第二种输入方式时,第一个参数一般填写this
,会调用qtconcurrentrun
的这个函数:
QFuture<T> run(Class *object, T (Class::*fn)())
{
return (new typename SelectStoredMemberFunctionPointerCall0<T, Class>::type(fn, object))->start();
}
可能如果输入的对象不再元对象体系中就会出问题吧。
注:
QThreadPool
是由QObject
派生而来,
版权声明:本文为amnesiagreen原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。