QtConcurrent系列之run函数创建多线程

在Qt多线程编程中,我们一般使用QThread,QRunnable等类来实现多线程。除此之外,QT还提供了一个更高级的实现多线程的方式,那就是QtConcurrent框架,QtConcurrent框架中提供了许多高级的,性能更好的多线程API函数,这些函数非常方便使用。本文重点介绍QtConcurrent:run函数,使用该函数可以方便的创建一个多线程。
使用QTConcurrent之前,需要在Pro工程文件中添加 Qt += concurrent,并且在头文件加上#include ,QtConcurrent:run函数有两个重载,分别是:

    QFuture<T> QtConcurrent::run(Function function, ...);
    QFuture<T> QtConcurrent::run(QThreadPool *pool, Function function, ...)

第一个函数等同于QtConcurrent::run(QThreadPool::globalInstance(), function, …);使用的时候只需往该函数传递一个函数对象即可,比如:

void myFunc(int max)
{

    for(auto i = 0;i< 10;i++)
    {
        qDebug() << "this is NO." << i;
        QThread::sleep(1);
    }
}

#include 
#include 
#include 
int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
	QtConcurrent::run(myFunc)return a.exec();
	}

也可以使用自己定义的QThreadPool对象并传递给run函数。

#include 
#include 
#include 
int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    
    QThreadPool pool;
	QtConcurrent::run(&pool,myFunc)return a.exec();
	}

QtConcurrent:run的返回值是QFurutre,是一个监控线程并异步获取线程结果的类,这里暂不介绍了。
我们也可以向QtConcurrent:run里面的线程函数传递参数。

void myFunc(int max)
{

    for(auto i = 0;i< max;i++)
    {
        qDebug() << "this is NO." << i;
        QThread::sleep(1);
    }
}

#include 
#include 
int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
	QtConcurrent::run(myFunc,20)return a.exec();

另外,QtConcurrent:run函数也可以接受成员函数,但是要求传递的变量需要是常量引用或者指针,传递的函数是常量成员函数时则传递常量引用,函数是非常量成员函数时则传递指针。比如:

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

你可能感兴趣的:(QT)