std::experimental::optional<T>:: value_or
From cppreference.net
<
cpp
|
experimental
|
optional
|
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
Exécuter ce code
#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) |