std::execution::seq, std::execution::par, std::execution::par_unseq, std::execution::unseq
Von cppreference.com
| Definiert in Header <execution> |
||
| inline constexpr std::execution::sequenced_policy seq { /* nicht spezifiziert */ }; |
(seit C++17) | |
| inline constexpr std::execution::parallel_policy par { /* nicht spezifiziert */ }; |
(seit C++17) | |
| inline constexpr std::execution::parallel_unsequenced_policy par_unseq { /* nicht spezifiziert */ }; |
(seit C++17) | |
| inline constexpr std::execution::unsequenced_policy unseq { /* nicht spezifiziert */ }; |
(seit C++20) | |
Die Ausführungs-Policy-Typen
- std::execution::sequenced_policy,
- std::execution::parallel_policy,
- std::execution::parallel_unsequenced_policy, und
- std::execution::unsequenced_policy
haben die folgenden jeweiligen Instanzen
-
std::execution::seq, -
std::execution::par, -
std::execution::par_unseq, und -
std::execution::unseq.
Diese Instanzen werden verwendet, um die Ausführungs-Policy von parallelen Algorithmen festzulegen, d.h. welche Arten von Parallelität zulässig sind.
Zusätzliche Ausführungs-Policies können von einer Standardbibliotheksimplementierung bereitgestellt werden (mögliche zukünftige Ergänzungen könnten std::parallel::cuda und std::parallel::opencl umfassen).
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#include <algorithm> #include <chrono> #include <cstdint> #include <iostream> #include <random> #include <vector> #ifdef PARALLEL #include <execution> namespace execution = std::execution; #else enum class execution { seq, unseq, par_unseq, par }; #endif void measure([[maybe_unused]] auto policy, std::vector<std::uint64_t> v) { const auto start = std::chrono::steady_clock::now(); #ifdef PARALLEL std::sort(policy, v.begin(), v.end()); #else std::sort(v.begin(), v.end()); #endif const auto finish = std::chrono::steady_clock::now(); std::cout << std::chrono::duration_cast<std::chrono::milliseconds>(finish - start) << '\n'; }; int main() { std::vector<std::uint64_t> v(1'000'000); std::mt19937 gen {std::random_device{}()}; std::ranges::generate(v, gen); measure(execution::seq, v); measure(execution::unseq, v); measure(execution::par_unseq, v); measure(execution::par, v); }
Mögliche Ausgabe
// online GNU/gcc compiler (PARALLEL macro is not defined) 81ms 80ms 79ms 78ms // with g++ -std=c++23 -O3 ./test.cpp -ltbb -DPARALLEL 165ms 163ms 30ms 27ms
[bearbeiten] Siehe auch
| (C++17)(C++17)(C++17)(C++20) |
Ausführungsrichtlinientypen (Klasse) |