std::apply
De cppreference.com
<tbody>
</tbody>
| Definido en el archivo de encabezado <tuple>
|
||
template <class F, class Tuple> constexpr decltype(auto) apply(F&& f, Tuple&& t); |
(desde C++17) | |
Invoca al objeto invocable (Callable) f con una tupla de argumentos.
Parámetros
| f | - | El objeto invocable (Callable) a ser invocado. |
| t | - | Tupla cuyos elementos serán usados como argumentos para f.
|
Valor de retorno
El valor devuelto por f.
Notas
La tupla no tiene que ser necesariamente std::tuple, y en su lugar puede ser cualquier cosa que soporte std::get y std::tuple_size; en particular, pueden usarse std::array y std::pair.
Posible implementación
namespace detail {
template <class F, class Tuple, std::size_t... I>
constexpr decltype(auto) apply_impl(F&& f, Tuple&& t, std::index_sequence<I...>)
{
// Esta implementación es válida desde C++20 (vía P1065R2)
// En C++17, aquí se necesita una contraparte constexpr de std::invoke
return std::invoke(std::forward<F>(f), std::get<I>(std::forward<Tuple>(t))...);
}
} // namespace detail
template <class F, class Tuple>
constexpr decltype(auto) apply(F&& f, Tuple&& t)
{
return detail::apply_impl(
std::forward<F>(f), std::forward<Tuple>(t),
std::make_index_sequence<std::tuple_size_v<std::remove_reference_t<Tuple>>>{});
}
|
Ejemplo
Ejecuta este código
#include <iostream>
#include <tuple>
#include <utility>
int add(int first, int second) { return first + second; }
template<typename T>
T add_generic(T first, T second) { return first + second; }
auto add_lambda = [](auto first, auto second) { return first + second; };
template<typename... Ts>
std::ostream& operator<<(std::ostream& os, std::tuple<Ts...> const& theTuple)
{
std::apply
(
[&os](Ts const&... tupleArgs)
{
os << '[';
std::size_t n{0};
((os << tupleArgs << (++n != sizeof...(Ts) ? ", " : "")), ...);
os << ']';
}, theTuple
);
return os;
}
int main()
{
// de acuerdo
std::cout << std::apply(add, std::pair(1, 2)) << '\n';
// ERROR: no puede deducirse el tipo de función
// std::cout << std::apply(add_generic, std::make_pair(2.0f, 3.0f)) << '\n';
// de acuerdo
std::cout << std::apply(add_lambda, std::pair(2.0f, 3.0f)) << '\n';
// ejemplo avanzado
std::tuple myTuple(25, "Hola", 9.31f, 'c');
std::cout << myTuple << '\n';
}
Salida:
3
5
[25, Hola, 9.31, c]
Véase también
| Crea un objeto de tupla del tipo definido por los tipos de argumentos. (plantilla de función) | |
| Crea una tupla de referencias r-valor. (plantilla de función) | |
(C++17) |
Construye un objeto con una tupla de argumentos. (plantilla de función) |
(C++17)(C++23) |
Invoca cualquier objeto Callable con los argumentos dados y la posibilidad de especificar el tipo de retorno. (desde C++23) (plantilla de función) |