std::expected<T,E>::or_else
De cppreference.com
| 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.
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
| Esta sección está incompleta Razón: sin 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.
|
- ↑
value()requiere queEsea construible por copia (véase Asunto LWG 3843), perooperator*no. - ↑
**thispuede 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) |