Espacios de nombres
Variantes

std::expected<T,E>::or_else

De cppreference.com
 
 
Biblioteca de servicios
 
 
Plantilla principal
template< class F > constexpr auto or_else( F&& f ) &;
(1) (desde C++23)
template< class F > constexpr auto or_else( F&& f ) const&;
(2) (desde C++23)
template< class F > constexpr auto or_else( F&& f ) &&;
(3) (desde C++23)
template< class F > constexpr auto or_else( F&& f ) const&&;
(4) (desde C++23)
Especialización parcial void
template< class F > constexpr auto or_else( F&& f ) &;
(5) (desde C++23)
template< class F > constexpr auto or_else( F&& f ) const&;
(6) (desde C++23)
template< class F > constexpr auto or_else( F&& f ) &&;
(7) (desde C++23)
template< class F > constexpr auto or_else( F&& f ) const&&;
(8) (desde C++23)

Si *this representa un valor esperado, invoca a f con el valor no esperado de *this como argumento y devuelve su resultado. En caso contrario, devuelve un objeto std::expected que representa un valor esperado.

1-4) El valor esperado se inicializa con el valor esperado val de *this.

Dado el tipo G como:

1,2) std::remove_cvref_t<std::invoke_result_t<F, decltype(error())>>
3,4) std::remove_cvref_t<std::invoke_result_t<F, decltype(std::move(error()))>>
5,6) std::remove_cvref_t<std::invoke_result_t<F, decltype(error())>>
7,8) std::remove_cvref_t<std::invoke_result_t<F, decltype(std::move(error()))>>

Si G no es una especialización de std::expected, o std::is_same_v<G::value_type, T> es false, el programa está mal formado.

1,2) Estas sobrecargas solo participan en la resolución de sobrecargas si std::is_constructible_v<T, decltype((val))> es true.
3,4) Estas sobrecargas solo participan en la resolución de sobrecargas si std::is_constructible_v<T, decltype(std::move(val))> es true.

Parámetros

f - Una función adecuada o un objeto Callable que devuelva un objeto std::expected.

Valor de retorno

 Sobrecarga  Valor de has_value()
true false
(1,2) G(std::in_place, val) std::invoke(std::forward<F>(f), error())
(3,4) G(std::in_place, std::move(val)) std::invoke(std::forward<F>(f), std::move(error()))
(5,6) G() std::invoke(std::forward<F>(f), error())
(7,8) std::invoke(std::forward<F>(f), std::move(error()))

Notas

Macro de prueba de característica Valor Estándar Comentario
__cpp_lib_expected 202211L (C++23) Funciones monádicas para std::expected.

Ejemplo

Informes de defectos

Los siguientes informes de defectos de cambio de comportamiento se aplicaron de manera retroactiva a los estándares de C++ publicados anteriormente.

ID Aplicado a Comportamiento según lo publicado Comportamiento correcto
LWG 3938 C++23 El valor esperado se obtenía por value().[1] Se cambió a **this.
LWG 3973 C++23 El valor esperado se obtenía por **this.[2] Se cambió a val.
  1. value() requiere que E sea construible por copia (véase Asunto LWG 3843), pero operator* no.
  2. **this puede activar la búsqueda dependiente de argumento.

Véase también

Devuelve el propio objeto expected si contiene un valor esperado; de lo contrario, devuelve un objeto expected que contiene el valor no esperado transformado.
(función miembro pública) [editar]