std::experimental::optional<T>::value_or
Von cppreference.com
< cpp | experimental | optional
| template< class U > constexpr T value_or( U&& default_value ) const&; |
(library fundamentals TS) | |
| template< class U > constexpr T value_or( U&& default_value ) &&; |
(library fundamentals TS) | |
Gibt den enthaltenen Wert zurück, wenn *this einen Wert hat, andernfalls wird default_value zurückgegeben.
1) Äquivalent zu bool(*this) ? **this : static_cast<T>(std::forward<U>(default_value)).
2) Äquivalent zu bool(*this) ? std::move(**this) : static_cast<T>(std::forward<U>(default_value)).
Inhalt |
[bearbeiten] Parameter
| default_value | - | Der Wert, der verwendet werden soll, falls *this leer ist. |
| Typanforderungen | ||
-T muss die Anforderungen an CopyConstructible erfüllen, um Überladung (1) zu verwenden. | ||
-T muss die Anforderungen an MoveConstructible erfüllen, um Überladung (2) zu verwenden. | ||
-U&& muss nach T konvertierbar sein. | ||
[bearbeiten] Rückgabewert
Der aktuelle Wert, wenn *this einen Wert hat, andernfalls default_value.
[bearbeiten] Ausnahmen
Jede Ausnahme, die vom ausgewählten Konstruktor des Rückgabewerts T ausgelöst wird.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#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'; }
Mögliche Ausgabe
(none)
[bearbeiten] Siehe auch
| gibt den enthaltenen Wert zurück (public member function) |