Qt多线程-总结QThread-QThreadPool-QtConcurrent

本文总结了Qt中多线程的三种实现方式:QThread、QThreadPool和QtConcurrent。QThread提供基础线程管理,QThreadPool为线程池,QtConcurrent则提供并行计算的高级API。详细对比了它们在事件处理、信号槽、线程优先级等方面的特点,并给出了不同场景下的推荐使用方案。
 

总结

QThread:Qt提供的最基础的线程类,一个对象管理一个线程,自己维护线程启动停止,创建销毁,当然也能基于此类自己建立一个线程池

QThreadPool:Qt提供的基于QThread实现的线程池,只需要提供给线程池“任务”即可,每一个“任务”需要继承QRunnable,pool还贴心的帮忙在运行完成后释放内存。只不过runnable不支持信号槽,可以做多重继承QObject即可。

QtConcurrent:并行计算的高级API,用起来很方便,完全不需要想线程的问题,全都是静态函数,可以运行自定义函数也提供了对容器的操作函数。

相关博客:

Qt多线程-QThread
QThread安全的结束线程
Qt多线程-QThreadPool线程池与QRunnable
Qt多线程-QtConcurrent并行运算高级API

详细对比

Qt事件处理

只有QThread支持。但是其他两个可以用QApplication::postEvent发出事件

Qt信号槽

QThread完全支持,QThreadPool的QRunnable可以通过多重继承支持

Concurrent提供的map/filter函数可以利用QFutureWatcher,使用此方式可用信号控制线程,但仍然无发通过信号槽对线程的数据做修改

run就完全与信号槽无缘了,毕竟调用的只

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值