std::optional<T>::value_or
Материал из cppreference.com
template<class U > constexpr T value_or( U&& default_value )const&; | (1) | (начиная с C++17) |
template<class U > constexpr T value_or( U&& default_value )&&; | (2) | (начиная с C++17) |
Возвращает содержащееся значение, если *this имеет значение, иначе возвращает default_value.
1) Эквивалентно bool(*this)?**this :static_cast<T>(std::forward<U>(default_value))
2) Эквивалентно bool(*this)? std::move(**this):static_cast<T>(std::forward<U>(default_value))
Содержание |
[править]Параметры
default_value | — | значение, используемое в случае, если *this пусто |
Требования к типам | ||
-T должен соответствовать требованиям CopyConstructible чтобы использовать перегрузку (1). | ||
-T должен соответствовать требованиям MoveConstructible чтобы использовать перегрузку (2). | ||
-U&& должен быть преобразуем в T |
[править]Возвращаемое значение
Текущее значение, если *this имеет значение, или default_value иначе.
[править]Исключения
Любое исключение, сгенерированное выбранным конструктором возвращаемого значения T
.
[править]Пример
Запустить этот код
#include <optional>#include <iostream>#include <cstdlib> std::optional<constchar*> maybe_getenv(constchar* n){if(constchar* x =std::getenv(n))return x;elsereturn{};}int main(){std::cout<< maybe_getenv("SHELL").value_or("(нет)")<<'\n';std::cout<< maybe_getenv("MYPWD").value_or("(нет)")<<'\n';}
Возможный вывод:
/usr/bin/zsh (нет)
[править]Смотрите также
возвращает содержащееся значение (public функция-элемент) |