Espacios de nombres
Variantes
Acciones

std::apply

De cppreference.com
< cpp‎ | utility
 
 
Biblioteca de servicios
Servicios generales
Operadores relacionales (en desuso en C++20)
 
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::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>>>{});
}

[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 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]

[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]