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 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/amnesiagreen/article/details/116587497