std::optional<T>::value_or
Материал из cppreference.com
<tbody>
</tbody>
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 функция-элемент) |