Namespaces
Variants

deduction guides for std::packaged_task

From cppreference.net
Concurrency support library
Threads
(C++11)
(C++20)
this_thread namespace
(C++11)
(C++11)
Cooperative cancellation
Mutual exclusion
Generic lock management
Condition variables
(C++11)
Semaphores
Latches and Barriers
(C++20)
(C++20)
Futures
(C++11)
(C++11)
(C++11)
Safe reclamation
Hazard pointers
Atomic types
(C++11)
(C++20)
Initialization of atomic types
(C++11) (deprecated in C++20)
(C++11) (deprecated in C++20)
Memory ordering
(C++11) (deprecated in C++26)
Free functions for atomic operations
Free functions for atomic flags
Défini dans l'en-tête <future>
template < class R, class ... Args >
packaged_task ( R ( * ) ( Args... ) ) - > packaged_task < R ( Args... ) > ;
(1) (depuis C++17)
template < class F >
packaged_task ( F ) - > packaged_task < /*voir ci-dessous*/ > ;
(2) (depuis C++17)
template < class F >
packaged_task ( F ) - > packaged_task < /*voir ci-dessous*/ > ;
(3) (depuis C++23)
template < class F >
packaged_task ( F ) - > packaged_task < /*voir ci-dessous*/ > ;
(4) (depuis C++23)
1) Ce guide de déduction est fourni pour std::packaged_task afin de permettre la déduction à partir des fonctions.
2) Cette surcharge participe à la résolution de surcharge uniquement si & F :: operator ( ) est bien formé lorsqu'il est traité comme un opérande non évalué et que decltype ( & F :: operator ( ) ) est de la forme R ( G :: * ) ( A... ) (éventuellement qualifié cv, éventuellement noexcept, éventuellement qualifié par une référence lvalue). Le type déduit est std:: packaged_task < R ( A... ) > .
3) Cette surcharge participe à la résolution de surcharge uniquement si & F :: operator ( ) est bien formé lorsqu'il est traité comme un opérande non évalué et F :: operator ( ) est une fonction à paramètre objet explicite dont le type est de la forme R ( G, A... ) ou R ( G, A... ) noexcept . Le type déduit est std:: packaged_task < R ( A... ) > .
4) Cette surcharge participe à la résolution de surcharge uniquement si & F :: operator ( ) est bien formé lorsqu'il est traité comme un opérande non évalué et F :: operator ( ) est une fonction membre statique dont le type est de la forme R ( A... ) ou R ( A... ) noexcept . Le type déduit est std:: packaged_task < R ( A... ) > .

Notes

Ces guides de déduction ne permettent pas la déduction à partir d'une fonction avec un paramètre ellipsis , et le ... dans les types est toujours traité comme une expansion de pack .

Exemple

#include <future>
int func(double) { return 0; }
int main()
{
    std::packaged_task f{func}; // déduit packaged_task<int(double)>
    int i = 5;
    std::packaged_task g = [&](double) { return i; }; // => packaged_task<int(double)>
}