Qt 之 QtConcurrent

本文深入解析QtConcurrent::run()函数,演示如何在Qt中利用此函数将任务分配到不同线程,实现多线程编程。通过具体代码示例,展示了普通函数和成员函数在独立线程中的调用方法。

本文以 Qt 中的 QtConcurrent::run() 函数为例,介绍如何将函数运行在单独的某一个线程中。

1  QtConcurrent::run()

  QtConcurrent 是一个命名空间,它提供了高层次的函数接口 (APIs),使得编写的程序,可根据当前计算机中实际的 CPU 核数,自动调整运行的线程数目。

  下面是 Qt 中的自带例程 runfunction,对应于安装目录为  D:\Qt\Qt5.8.0\Examples\Qt-5.8\qtconcurrent\runfucntion

1.1  .pro 工程文件

  使用 QtConcurrent 模块,需要在 .pro 中添加: QT += concurrent

QT += concurrent widgets
CONFIG += console
CONFIG -= app_bundle

SOURCES += main.cpp

1.2  main.cp

#include <QApplication>
#include <QDebug>
#include <QThread>

#include <QString>
#include <QtConcurrent>

void func(QString name)
{
    qDebug() << "Hello" << name << "from" << QThread::currentThread();
}

int main(int argc, char **argv)
{
    QApplication app(argc, argv);

    QFuture<void> fut1 = QtConcurrent::run(func, QString("Thread 1"));
    QFuture<void> fut2 = QtConcurrent::run(func, QString("Thread 2"));

    fut1.waitForFinished();
    fut2.waitForFinished();
}

 

 

可以看到,使用 QtConcurrent::run() 函数,分别将  func() 运行在两个不同的线程之中,输出的结果如下:

Hello "Thread 2" from QThread(0x3597f0, name = "Thread (pooled)")
Hello "Thread 1" from QThread(0x337720, name = "Thread (pooled)")

 

  下面是对使用 QtConcurrent::run() 的详细阐释,阅读完 2 和 3,再来看上面的 runfunction 例程,就非常容易理解了。

 2  普通函数

2.1  将函数运行在某一个线程中

extern void func();
QFuture<void> future = QtConcurrent::run(func);

  如果要为其指定线程池,可以将线程池的指针作为第一个参数传递进去

extern void func();
QThreadPool pool;
QFuture<void> future = QtConcurrent::run(&pool, func);

2.2  向该函数传递参数

  需要传递的参数,需要跟在函数名之后,依次加入

extern void FuncWithArguments(int arg1, const QString &string);

 int integer = ...;
 QString string = ...;

 QFuture<void> future = QtConcurrent::run(FuncWithArguments,integer,string);

2.3  获取该函数的计算结果

 

extern QString Func(const QByteArray &input);

QByteArray byte_array = ...;

QFuture<QString> future = QtConcurrent::run(func, byte_array);
...
QString result = future.result();

 

3  成员函数

  要将类中的成员函数运行在某一个线程中,可将指向该类实例的 引用或指针 作为 QtConcurrent::run 的第一个参数传递进去,

  常量成员函数一般传递 常量引用 (const reference),而非常量成员函数一般传递 指针 (pointer)

3.1  常量成员函数

   在一个单独的线程中,调用 QByteArray 的常量成员函数 split(),传递给 run() 函数的参数是 bytearray

  QByteArray bytearray = "hello world";
  QFuture<QList<QByteArray> > future = QtConcurrent::run(bytearray, &QByteArray::split, ',');
  ...
  QList<QByteArray> result = future.result();

3.2  非常量成员函数

   在一个单独的线程中,调用 QImage 的非常量成员函数 invertPixels(),传递给 run() 函数的参数是 &image

  QImage image = ...;
  QFuture<void> future = QtConcurrent::run(&image, &QImage::invertPixels, QImage::InvertRgba);
  ...
  future.waitForFinished();
  // At this point, the pixels in 'image' have been inverted

 

参考资料:

  Qt 助手 | Qt 5.8 | Qt Concurrent | Concurrent Run

转自:https://www.cnblogs.com/xinxue/p/6840315.html

<think>我们被要求回答关于"Qt QtConcurrent模块不存在"的解决方法。根据引用资料,QtConcurrentQt框架中的一个模块,用于简化多线程编程。如果用户遇到模块不存在的问题,可能是由于以下原因: 1. 项目配置中未启用QtConcurrent模块。 2. 使用的Qt版本不支持QtConcurrent。 3. 在.pro文件中未添加对应的模块。 根据引用[2]和[4],QtConcurrent模块需要包含对应的头文件并在项目配置中启用。因此,我们可以提供以下步骤: **步骤1:检查Qt版本** 确保使用的Qt版本包含QtConcurrent模块。该模块在Qt4和Qt5中都是核心模块的一部分,但在某些定制版本中可能被排除。 **步骤2:在.pro文件中添加模块** 在Qt项目文件(.pro)中添加: ``` QT += concurrent ``` 然后重新运行qmake并重新构建项目。 **步骤3:检查头文件包含** 在代码中,确保包含了必要的头文件,例如: ```cpp #include <QtConcurrent> ``` **步骤4:检查编译环境** 如果使用CMake,需要在CMakeLists.txt中添加: ```cmake find_package(Qt5 COMPONENTS Concurrent REQUIRED) # 对于Qt5 target_link_libraries(your_target PRIVATE Qt5::Concurrent) ``` 对于Qt6,同样需要链接Concurrent模块。 **步骤5:确认模块是否安装** 在Qt安装目录下检查是否存在QtConcurrent模块的文件(例如:在include目录下是否有QtConcurrent目录)。 如果以上步骤都无效,可能需要重新安装Qt并确保安装时选择了该模块。 §§相关问题§§ 1. 如何在CMake项目中配置QtConcurrent模块? 2. QtConcurrent模块在哪些Qt版本中被引入? 3. 如何检查Qt安装中是否包含QtConcurrent模块? 4. 使用QtConcurrent时需要注意哪些常见问题?</think>### QtConcurrent模块不存在解决方法 当遇到QtConcurrent模块不存在的问题时,可按以下步骤解决: 1. **检查.pro项目配置文件** 在Qt项目文件(.pro)中添加模块声明: ```qmake QT += concurrent ``` 保存后重新运行qmake并重新构建项目[^4]。 2. **验证Qt安装版本** QtConcurrent模块需要: - Qt 5.0+ 完整安装(非MinGW精简版) - 在安装时勾选`Qt Concurrent`组件(默认包含在完整安装中) ```bash qmake -v # 查看Qt版本 ``` 3. **CMake项目配置(Qt6适用)** 在CMakeLists.txt中添加: ```cmake find_package(Qt6 COMPONENTS Concurrent REQUIRED) target_link_libraries(your_target PRIVATE Qt6::Concurrent) ``` 4. **检查头文件包含** 确保代码中包含正确头文件: ```cpp #include <QtConcurrent> // Qt5 #include <QtConcurrent/QtConcurrent> // Qt6 ``` 5. **排查常见安装问题**: - 精简版Qt可能缺失该模块,需下载完整离线安装包 - 通过Qt Maintenance Tool添加`Qt Concurrent`组件 - Linux系统需安装`qtbase5-dev`或`qt6-base-dev`包 6. **运行时验证** 创建测试代码验证: ```cpp #include <QtConcurrent> int main() { auto future = QtConcurrent::run([](){ return 42; }); return future.result(); } ``` > **注意**:QtConcurrent在移动平台(Android/iOS)需要额外配置,需在.pro文件中添加: > ```qmake CONFIG += concurrent ``` [^1]: QtConcurrent模块提供高级API实现并行计算,无需直接管理线程 [^2]: 该模块允许开发者无需使用低级线程原语编写多线程程序 [^4]: 通过QFuture和QThreadPool自动利用系统多核处理器
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值