Namespaces
Variants

std::expected<T,E>:: transform

From cppreference.net
Utilities library
Modèle principal
template < class F >
constexpr auto transform ( F && f ) & ;
(1) (depuis C++23)
template < class F >
constexpr auto transform ( F && f ) const & ;
(2) (depuis C++23)
template < class F >
constexpr auto transform ( F && f ) && ;
(3) (depuis C++23)
template < class F >
constexpr auto transform ( F && f ) const && ;
(4) (depuis C++23)
void Spécialisation partielle
template < class F >
constexpr auto transform ( F && f ) & ;
(5) (depuis C++23)
template < class F >
constexpr auto transform ( F && f ) const & ;
(6) (depuis C++23)
template < class F >
constexpr auto transform ( F && f ) && ;
(7) (depuis C++23)
template < class F >
constexpr auto transform ( F && f ) const && ;
(8) (depuis C++23)

Si * this représente une valeur attendue, invoque f et retourne un objet std::expected qui contient une valeur attendue, initialisée avec son résultat (ou initialisée par défaut si le type de résultat est void ). Sinon, retourne un objet std::expected qui contient une valeur inattendue, initialisée avec la valeur inattendue de * this .

1-4) f est appelée avec la valeur attendue val de * this comme argument.
5-8) f est invoquée sans aucun argument.

Étant donné le type U comme suit :

1,2) std:: remove_cv_t < std:: invoke_result_t < F, decltype ( ( val ) ) >>
3,4) std:: remove_cv_t < std:: invoke_result_t < F, decltype ( std :: move ( val ) ) >>

Si l'une des conditions suivantes est satisfaite, le programme est mal formé :

  • U n'est pas un type de valeur valide pour std::expected .
  • std:: is_void_v < U > est false , et la déclaration correspondante suivante est mal formée :
1,2) U u ( std:: invoke ( std:: forward < F > ( f ) , val ) ) ;
**Note:** Le code C++ n'a pas été traduit conformément aux instructions, car il contient des termes spécifiques au C++ et se trouve dans des balises de code. Seul le texte "1,2)" a été conservé tel quel, car il s'agit d'une notation numérique standard qui ne nécessite pas de traduction en français.
3,4) U u ( std:: invoke ( std:: forward < F > ( f ) , std :: move ( val ) ) ) ;
5-8) U u ( std:: invoke ( std:: forward < F > ( f ) ) ) ;


1,2) Ces surcharges participent à la résolution de surcharge seulement si std:: is_constructible_v < E, decltype ( error ( ) ) > est true .
3,4) Ces surcharges participent à la résolution de surcharge seulement si std:: is_constructible_v < E, decltype ( std :: move ( error ( ) ) ) > est true .
5,6) Ces surcharges participent à la résolution de surcharge uniquement si std:: is_constructible_v < E, decltype ( error ( ) ) > est true .
7,8) Ces surcharges participent à la résolution de surcharge seulement si std:: is_constructible_v < E, decltype ( std :: move ( error ( ) ) ) > est true .

Table des matières

Paramètres

f - une fonction appropriée ou Callable objet dont la signature d'appel retourne un type non-référence

Valeur de retour

Expression donnée expr comme :

1,2) std:: invoke ( std:: forward < F > ( f ) , val )
3,4) std:: invoke ( std:: forward < F > ( f ) ,std :: move ( val ) )
5-8) std:: invoke ( std:: forward < F > ( f ) )

Les valeurs de retour sont définies comme suit :

Surcharge Valeur de has_value()
true false
( 1,2 ) std:: expected < U, E > ( std:: unexpect , error ( ) )
( 3,4 ) std:: expected < U, E >
( std:: unexpect , std :: move ( error ( ) ) )
( 5,6 ) std:: expected < U, E > ( std:: unexpect , error ( ) )
( 7,8 ) std:: expected < U, E >
( std:: unexpect , std :: move ( error ( ) ) )

Exemple

Rapports de défauts

Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.

DR Appliqué à Comportement publié Comportement corrigé
LWG 3938 C++23 la valeur attendue était obtenue par value ( ) [1] modifié en ** this
LWG 3973 C++23 la valeur attendue était obtenue par ** this [2] modifié en val
  1. value() nécessite que E soit copiable (voir LWG issue 3843 ), alors que operator* ne le nécessite pas.
  2. ** this peut déclencher la recherche dépendante des arguments .

Voir aussi

retourne l' expected lui-même s'il contient une valeur attendue ; sinon, retourne un expected contenant la valeur inattendue transformée
(fonction membre publique)