std::optional<T>::or_else
Материал из cppreference.com
template< class F > constexpr optional or_else( F&& f ) const&; |
(1) | (начиная с C++23) |
template< class F > constexpr optional or_else( F&& f ) &&; |
(2) | (начиная с C++23) |
Возвращает *this, если оно содержит значение. В противном случае возвращает результат f
.
Программа некорректна, если std::remove_cvref_t<std::invoke_result_t<F>> не совпадает с std::optional<T>.
1) Эквивалентно return *this ? *this : std::forward<F>(f)();. Эта перегрузка участвует в разрешении перегрузки, только если моделируются как std::copy_constructible<T>, так и std::invocable<F>.
2) Эквивалентно return *this ? std::move(*this) : std::forward<F>(f)();. Эта перегрузка участвует в разрешении перегрузки, только если моделируются как std::move_constructible<T>, так и std::invocable<F>.
Содержание |
[править] Параметры
f | — | функция или объект Callable, которые возвращают std::optional<T> |
[править] Возвращаемое значение
*this или результат f
, как описано выше.
[править] Примечание
Макрос Тестирования функциональности | Значение | Стандарт | Функциональность |
---|---|---|---|
__cpp_lib_optional |
202110L | (C++23) | Монадические операции в std::optional |
[править] Пример
Этот раздел не завершён Причина: нет примера |
[править] Смотрите также
возвращает содержащееся значение, если доступно, иначе другое значение (public функция-элемент) | |
(C++23) |
возвращает результат данной функции по содержащемуся значению, если оно существует, или пустой optional в противном случае (public функция-элемент) |
(C++23) |
возвращает optional , содержащий преобразованное содержащееся значение, если оно существует, или пустой optional в противном случае (public функция-элемент) |