QtConcurrent非常用方法

本文介绍了QtConcurrent命名空间下的高级API,如Filter用于多线程过滤序列,blockingFilter与filtered的区别,以及map接口的映射功能。重点讲解了阻塞操作和并行计算的实现,如filteredReduced和run方法的应用。
摘要由CSDN通过智能技术生成

QtConcurrent 命名空间下高级API

Filter

void blockingFilter(Sequence &sequence, FilterFunction filterFunction)
Sequence blockingFiltered(const Sequence &sequence, FilterFunction filterFunction)
Sequence blockingFiltered(ConstIterator begin, ConstIterator end, FilterFunction filterFunction)

T blockingFilteredReduced(const Sequence &sequence, FilterFunction filterFunction, ReduceFunction reduceFunction, QtConcurrent::ReduceOptions reduceOptions = UnorderedReduce | SequentialReduce)

T blockingFilteredReduced(ConstIterator begin, ConstIterator end, FilterFunction filterFunction, ReduceFunction reduceFunction, QtConcurrent::ReduceOptions reduceOptions = UnorderedReduce | SequentialReduce)

QFuture filter(Sequence &sequence, FilterFunction filterFunction)

QFuture filtered(const Sequence &sequence, FilterFunction filterFunction)

QFuture filtered(ConstIterator begin, ConstIterator end, FilterFunction filterFunction)

QFuture filteredReduced(const Sequence &sequence, FilterFunction filterFunction, ReduceFunction reduceFunction, QtConcurrent::ReduceOptions reduceOptions = UnorderedReduce | SequentialReduce)

QFuture filteredReduced(ConstIterator begin, ConstIterator end, FilterFunction filterFunction, ReduceFunction reduceFunction, QtConcurrent::ReduceOptions reduceOptions = UnorderedReduce | SequentialReduce)

filteredReduced(ConstIterator begin, ConstIterator end, FilterFunction filterFunction, ReduceFunction reduceFunction, QtConcurrent::ReduceOptions reduceOptions = UnorderedReduce |顺序减少)

filteredReduced(ConstIterator begin, ConstIterator end, FilterFunction filterFunction, ReduceFunction reduceFunction, QtConcurrent::ReduceOptions reduceOptions = UnorderedReduce |顺序减少)

filteredReduced(ConstIterator begin, ConstIterator end, FilterFunction filterFunction, ReduceFunction reduceFunction, QtConcurrent::ReduceOptions reduceOptions = UnorderedReduce |顺序减少)

filteredReduced(ConstIterator begin, ConstIterator end, FilterFunction filterFunction, ReduceFunction reduceFunction, QtConcurrent::ReduceOptions reduceOptions = UnorderedReduce |顺序减少)

原本就是过滤器接口, Sequence 可以是QList<> QVector<>, 通过过滤器接口进行多线程过滤,经过第二个参数的function运算后,返回true的保留,否则去除。

blocking 表示阻塞的
后面加ed表示不动原来的容器,重新返回个满足条件的
reduced 后面再经过reduceFunction 运算,最后返回一个值。

map

接口和filter类似,但map是QList<>, QVector<>里的每个值通过运算再得到一个值,和原数据一一对应。

run

同步执行接口,执行函数体或线程池

QFuture run(Function function, …)
QFuture run(QThreadPool *pool, Function function, …)

  • 20
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值