Namensräume
Varianten
Aktionen

std::optional<T>::value_or

Von cppreference.com
< cpp‎ | utility‎ | optional
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
 
template< class U = std::remove_cv_t<T> >
constexpr T value_or( U&& default_value ) const&;
(1) (seit C++17)
template< class U = std::remove_cv_t<T> >
constexpr T value_or( U&& default_value ) &&;
(2) (seit C++17)

Gibt den enthaltenen Wert zurück, wenn *this einen Wert enthält, andernfalls wird default_value zurückgegeben.

1) Wenn std::is_copy_constructible_v<T> && std::is_convertible_v<U&&, T> false ist, ist das Programm schlecht geformt.
2) Wenn std::is_move_constructible_v<T> && std::is_convertible_v<U&&, T> false ist, ist das Programm schlecht geformt.

Inhalt

[bearbeiten] Parameter

default_value - der Wert, der zurückgegeben werden soll, wenn *this keinen Wert enthält

[bearbeiten] Rückgabewert

1) has_value() ? **this : static_cast<T>(std::forward<U>(default_value));
2) has_value() ? std::move(**this) : static_cast<T>(std::forward<U>(default_value))

[bearbeiten] Beispiel

#include <cstdlib>
#include <iostream>
#include <optional>
 
std::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("SHELL").value_or("(none)") << '\n';
    std::cout << maybe_getenv("MYPWD").value_or("(none)") << '\n';
}

Mögliche Ausgabe

/usr/bin/zsh
(none)

[bearbeiten] Fehlermeldungen

Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR angewendet auf Verhalten wie veröffentlicht Korrigiertes Verhalten
LWG 3886 C++17 U hat kein Standard-Template-Argument spezifiziert

[bearbeiten] Siehe auch

gibt den enthaltenen Wert zurück
(public member function) [edit]