std::apply
De cppreference.com
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.
Contenido |
[editar]Parámetros
f | - | El objeto invocable (Callable) a ser invocado. |
t | - | Tupla cuyos elementos serán usados como argumentos para f . |
[editar]Valor de retorno
El valor devuelto por f
.
[editar] 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.
[editar]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::invokereturnstd::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>>>{});} |
[editar]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 acuerdostd::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 acuerdostd::cout<< std::apply(add_lambda, std::pair(2.0f, 3.0f))<<'\n'; // ejemplo avanzadostd::tuple myTuple(25, "Hola", 9.31f, 'c');std::cout<< myTuple <<'\n'; }
Salida:
3 5 [25, Hola, 9.31, c]
[editar]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) |