Qt Concurrent

Getting Started

The QtConcurrent namespace provides high-level APIs that make it possible to write multi-threaded programs without using low-level threading primitives such as mutexes, read-write locks, wait conditions, or semaphores. Programs written with QtConcurrent automatically adjust the number of threads used according to the number of processor cores available. This means that applications written today will continue to scale when deployed on multi-core systems in the future.

QtConcurrent includes functional programming style APIs for parallel list processing, including a MapReduce and FilterReduce implementation for shared-memory (non-distributed) systems, and classes for managing asynchronous computations in GUI applications:

  • QtConcurrent::map() applies a function to every item in a container, modifying the items in-place.
  • QtConcurrent::mapped() is like map(), except that it returns a new container with the modifications.
  • QtConcurrent::mappedReduced() is like mapped(), except that the modified results are reduced or folded into a single result.
  • QtConcurrent::filter() removes all items from a container based on the result of a filter function.
  • QtConcurrent::filtered() is like filter(), except that it returns a new container with the filtered results.
  • QtConcurrent::filteredReduced() is like filtered(), except that the filtered results are reduced or folded into a single result.
  • QtConcurrent::run() runs a function in another thread.
  • QFuture represents the result of an asynchronous computation.
  • QFutureIterator allows iterating through results available via QFuture.
  • QFutureWatcher allows monitoring a QFuture using signals-and-slots.
  • QFutureSynchronizer is a convenience class that automatically synchronizes several QFutures.

Qt Concurrent supports several STL-compatible container and iterator types, but works best with Qt containers that have random-access iterators, such as QList or QVector. The map and filter functions accept both containers and begin/end iterators.

STL Iterator support overview:

Iterator TypeExample classesSupport status
Input IteratorNot Supported
Output IteratorNot Supported
Forward Iteratorstd::slistSupported
Bidirectional IteratorQLinkedList, std::listSupported
Random Access IteratorQList, QVector, std::vectorSupported and Recommended

Random access iterators can be faster in cases where Qt Concurrent is iterating over a large number of lightweight items, since they allow skipping to any point in the container. In addition, using random access iterators allows Qt Concurrent to provide progress information trough QFuture::progressValue() and QFutureWatcher::progressValueChanged().

The non in-place modifying functions such as mapped() and filtered() makes a copy of the container when called. If you are using STL containers this copy operation might take some time, in this case we recommend specifying the begin and end iterators for the container instead.

© 2015 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.