std::optional<T>:: and_then
|
template
<
class
F
>
constexpr auto and_then ( F && f ) & ; |
(1) | (desde C++23) |
|
template
<
class
F
>
constexpr auto and_then ( F && f ) const & ; |
(2) | (desde C++23) |
|
template
<
class
F
>
constexpr auto and_then ( F && f ) && ; |
(3) | (desde C++23) |
|
template
<
class
F
>
constexpr auto and_then ( F && f ) const && ; |
(4) | (desde C++23) |
Si
*
this
contiene un valor, invoca
f
con el valor contenido como argumento, y devuelve el resultado de esa invocación; de lo contrario, devuelve un
std::optional
vacío.
El tipo de retorno (ver abajo) debe ser una especialización de
std::optional
(a diferencia de
transform()
). De lo contrario, el programa está mal formado.
if (*this) return std::invoke(std::forward<F>(f), value()); else return std::remove_cvref_t<std::invoke_result_t<F, T&>>{};
if (*this) return std::invoke(std::forward<F>(f), value()); else return std::remove_cvref_t<std::invoke_result_t<F, const T&>>{};
if (*this) return std::invoke(std::forward<F>(f), std::move(value())); else return std::remove_cvref_t<std::invoke_result_t<F, T>>{};
if (*this) return std::invoke(std::forward<F>(f), std::move(value()); else return std::remove_cvref_t<std::invoke_result_t<F, const T>>{};
Contenidos |
Parámetros
| f | - | una función adecuada u Callable objeto que devuelve un std::optional |
Valor de retorno
El resultado de f o un std::optional vacío, como se describió anteriormente.
Notas
Algunos lenguajes llaman a esta operación flatmap .
| Macro de prueba de características | Valor | Estándar | Característica |
|---|---|---|---|
__cpp_lib_optional
|
202110L
|
(C++23) | Operaciones mónadicas en std::optional |
Ejemplo
#include <charconv> #include <iomanip> #include <iostream> #include <optional> #include <ranges> #include <string> #include <string_view> #include <vector> std::optional<int> to_int(std::string_view sv) { int r{}; auto [ptr, ec]{std::from_chars(sv.data(), sv.data() + sv.size(), r)}; if (ec == std::errc()) return r; else return std::nullopt; } int main() { using namespace std::literals; const std::vector<std::optional<std::string>> v { "1234", "15 foo", "bar", "42", "5000000000", " 5", std::nullopt, "-43" }; for (auto&& x : v | std::views::transform( [](auto&& o) { // impresión de depuración del contenido del optional<string> de entrada std::cout << std::left << std::setw(13) << std::quoted(o.value_or("nullopt")) << " -> "; return o // si el optional es nullopt, convertirlo a optional con string "" .or_else([]{ return std::optional{""s}; }) // flatmap de strings a ints (creando optionals vacíos donde falle) .and_then(to_int) // mapear int a int + 1 .transform([](int n) { return n + 1; }) // convertir de vuelta a strings .transform([](int n) { return std::to_string(n); }) // reemplazar todos los optionals vacíos que quedaron por // and_then e ignorados por transforms con "NaN" .value_or("NaN"s); })) std::cout << x << '\n'; }
Salida:
"1234" -> 1235 "15 foo" -> 16 "bar" -> NaN "42" -> 43 "5000000000" -> NaN " 5" -> NaN "nullopt" -> NaN "-43" -> -42
Véase también
|
devuelve el valor contenido si está disponible, otro valor en caso contrario
(función miembro pública) |
|
|
(C++23)
|
devuelve un
optional
que contiene el valor contenido transformado si existe, o un
optional
vacío en caso contrario
(función miembro pública) |
|
(C++23)
|
devuelve el propio
optional
si contiene un valor, o el resultado de la función dada en caso contrario
(función miembro pública) |