Namespaces
Variants

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

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

Si * this contient une valeur inattendue, invoque f avec la valeur inattendue de * this comme argument et retourne son résultat. Sinon, retourne un objet std::expected qui représente une valeur attendue.

1-4) La valeur attendue est initialisée avec la valeur attendue val de * this .

Étant donné le type G comme suit :

1,2) std:: remove_cvref_t < std:: invoke_result_t < F, decltype ( error ( ) ) >>
3,4) std:: remove_cvref_t < std:: invoke_result_t < F, decltype ( std :: move ( error ( ) ) ) >>
5,6) std:: remove_cvref_t < std:: invoke_result_t < F, decltype ( error ( ) ) >>
7,8) std:: remove_cvref_t < std:: invoke_result_t < F, decltype ( std :: move ( error ( ) ) ) >>

Si G n'est pas une spécialisation de std::expected , ou si std:: is_same_v < G :: value_type , T > est false , le programme est mal formé.

1,2) Ces surcharges participent à la résolution de surcharge seulement si std:: is_constructible_v < T, decltype ( ( val ) ) > est true .
3,4) Ces surcharges participent à la résolution de surcharge seulement si std:: is_constructible_v < T, decltype ( std :: move ( val ) ) > est true .

Table des matières

Paramètres

f - une fonction appropriée ou Callable object qui retourne un std::expected

Valeur de retour

Surcharge Valeur de has_value()
true false
( 1,2 ) G ( std:: in_place , val ) std:: invoke ( std:: forward < F > ( f ) , error ( ) )
( 3,4 ) G ( std:: in_place , std :: move ( val ) ) std:: invoke ( std:: forward < F > ( f ) , std :: move ( error ( ) ) )
( 5,6 ) G ( ) std:: invoke ( std:: forward < F > ( f ) , error ( ) )
( 7,8 ) std:: invoke ( std:: forward < F > ( f ) , std :: move ( error ( ) ) )

Notes

Macro de test de fonctionnalité Valeur Std Fonctionnalité
__cpp_lib_expected 202211L (C++23) Fonctions monadiques pour std::expected

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 une 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)