Namespaces
Variants

std::experimental::optional<T>:: value_or

From cppreference.net
template < class U >
constexpr T value_or ( U && default_value ) const & ;
(spécifications techniques des bibliothèques fondamentales)
template < class U >
constexpr T value_or ( U && default_value ) && ;
(spécifications techniques des bibliothèques fondamentales)

Retourne la valeur contenue si * this a une valeur, sinon retourne default_value .

1) Équivalent à bool ( * this ) ? ** this : static_cast < T > ( std:: forward < U > ( default_value ) ) .
2) Équivalent à bool ( * this ) ? std :: move ( ** this ) : static_cast < T > ( std:: forward < U > ( default_value ) ) .

Table des matières

Paramètres

default_value - la valeur à utiliser si * this est vide
Exigences de type
-
T doit satisfaire aux exigences de CopyConstructible pour utiliser la surcharge (1).
-
T doit satisfaire aux exigences de MoveConstructible pour utiliser la surcharge (2).
-
U&& doit être convertible en T .

Valeur de retour

La valeur actuelle si * this a une valeur, ou default_value sinon.

Exceptions

Toute exception levée par le constructeur sélectionné de la valeur de retour T .

Exemple

#include <cstdlib>
#include <experimental/optional>
#include <iostream>
std::experimental::optional<const char*> maybe_getenv(const char* n)
{
    if (const char* x = std::getenv(n))
        return x;
    else
        return {};
}
int main()
{
    std::cout << maybe_getenv("MYPWD").value_or("(none)") << '\n';
}

Sortie possible :

(none)

Voir aussi

retourne la valeur contenue
(fonction membre publique)