std::expected<T,E>::transform_error
De cppreference.com
| Plantilla primaria |
||
template< class F > constexpr auto transform_error( F&& f ) &; |
(1) | (desde C++23) |
template< class F > constexpr auto transform_error( F&& f ) const&; |
(2) | (desde C++23) |
template< class F > constexpr auto transform_error( F&& f ) &&; |
(3) | (desde C++23) |
template< class F > constexpr auto transform_error( F&& f ) const&&; |
(4) | (desde C++23) |
| Especialización parcial void |
||
template< class F > constexpr auto transform_error( F&& f ) &; |
(5) | (desde C++23) |
template< class F > constexpr auto transform_error( F&& f ) const&; |
(6) | (desde C++23) |
template< class F > constexpr auto transform_error( F&& f ) &&; |
(7) | (desde C++23) |
template< class F > constexpr auto transform_error( F&& f ) const&&; |
(8) | (desde C++23) |
Si *this contiene un valor no esperado, invoca a f con el valor no esperado de *this como argumento y devuelve un objeto std::expected que contiene un valor no esperado, el cual se inicializa con el resultado de f. En caso contrario, devuelve un objeto std::expected que representa un valor esperado.
Dado el tipo G como:
1,2)
std::remove_cv_t<std::invoke_result_t<F, decltype(error())>>3,4)
std::remove_cv_t<std::invoke_result_t<F, decltype(std::move(error()))>>5,6)
std::remove_cv_t<std::invoke_result_t<F, decltype(error())>>7,8)
std::remove_cv_t<std::invoke_result_t<F, decltype(std::move(error()))>>Si se cumple alguna de las siguientes condiciones, el programa está mal formado:
Gno es un argumento de plantilla válido parastd::unexpected.- La siguiente declaración correspondiente está mal formada:
1,2)
G g(std::invoke(std::forward<F>(f), error()));3,4)
G g(std::invoke(std::forward<F>(f), std::move(error()));5,6)
G g(std::invoke(std::forward<F>(f), error()));7,8)
G g(std::invoke(std::forward<F>(f), std::move(error()));
1,2) Esta sobrecarga solo participa en la resolución de sobrecargas si
std::is_constructible_v<T, decltype((val))> es true.3,4) Esta sobrecarga solo participa 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 cuya signatura de llamada devuelva un tipo no referencia. |
Valor de retorno
Dada la expresión expr como:
1,2)
std::invoke(std::forward<F>(f), error())3,4)
std::invoke(std::forward<F>(f), std::move(error()))5,6)
std::invoke(std::forward<F>(f), error())7,8)
std::invoke(std::forward<F>(f), std::move(error()))Los valores de retorno se definen de la siguiente manera:
| Sobrecarga | Valor de has_value()
| |
|---|---|---|
true
|
false
| |
| (1,2) | std::expected<T, G>(std::in_place, val)
|
std::expected<T, G>(std::unexpect, expr)
|
| (3,4) | std::expected<T, G>(std::in_place, std::move(val))
| |
| (5,6) | std::expected<T, G>()
| |
| (7,8) | ||
Notas
| Macro de prueba de característica | |||
|---|---|---|---|
__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 expected si contiene un valor esperado; de lo contrario, devuelve el resultado de la función dada en el valor no esperado. (función miembro pública) | |
Devuelve un objeto expected que contiene el valor esperado transformado si existe; de lo contrario, devuelve el propio expected. (función miembro pública) |