Espacios de nombres
Variantes
Acciones

std::apply

De cppreference.com
< cpp‎ | utility
 
 
Biblioteca de servicios
 
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

#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)[editar]
Crea una tupla de referencias r-valor.
(plantilla de función)[editar]
Construye un objeto con una tupla de argumentos.
(plantilla de función)[editar]
(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)[editar]
close