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<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("(нет)") << '\n'; std::cout << maybe_getenv("MYPWD").value_or("(нет)") << '\n'; }
Возможный вывод:
/usr/bin/zsh (нет)
[править] Смотрите также
возвращает содержащееся значение (public функция-элемент) |