Namespaces
Variants

std:: make_tuple

From cppreference.net
Utilities library
Definido en el encabezado <tuple>
template < class ... Types >
std:: tuple < VTypes... > make_tuple ( Types && ... args ) ;
(desde C++11)
(constexpr desde C++14)

Crea un objeto tupla, deduciendo el tipo objetivo a partir de los tipos de argumentos.

Para cada Ti en Types... , el tipo correspondiente Vi en VTypes... es std:: decay < Ti > :: type a menos que la aplicación de std::decay resulte en std:: reference_wrapper < X > para algún tipo X , en cuyo caso el tipo deducido es X& .

Contenidos

Parámetros

args - cero o más argumentos para construir la tupla

Valor de retorno

Un objeto std::tuple que contiene los valores dados, creado como si fuera mediante std:: tuple < VTypes... > ( std:: forward < Types > ( t ) ... ) .

Implementación posible

template <class T>
struct unwrap_refwrapper
{
    using type = T;
};
template <class T>
struct unwrap_refwrapper<std::reference_wrapper<T>>
{
    using type = T&;
};
template <class T>
using unwrap_decay_t = typename unwrap_refwrapper<typename std::decay<T>::type>::type;
// o usar std::unwrap_ref_decay_t (desde C++20)
template <class... Types>
constexpr // desde C++14
std::tuple<unwrap_decay_t<Types>...> make_tuple(Types&&... args)
{
    return std::tuple<unwrap_decay_t<Types>...>(std::forward<Types>(args)...);
}

Ejemplo

#include <iostream>
#include <tuple>
#include <functional>
std::tuple<int, int> f() // esta función retorna múltiples valores
{
    int x = 5;
    return std::make_tuple(x, 7); // return {x,7}; en C++17
}
int main()
{
    // construcción de tupla heterogénea
    int n = 1;
    auto t = std::make_tuple(10, "Test", 3.14, std::ref(n), n);
    n = 7;
    std::cout << "The value of t is ("
              << std::get<0>(t) << ", "
              << std::get<1>(t) << ", "
              << std::get<2>(t) << ", "
              << std::get<3>(t) << ", "
              << std::get<4>(t) << ")\n";
    // función que retorna múltiples valores
    int a, b;
    std::tie(a, b) = f();
    std::cout << a << ' ' << b << '\n';
}

Salida:

The value of t is (10, Test, 3.14, 7, 1)
5 7

Véase también

(C++11)
crea un tuple de referencias a lvalue o desempaqueta un tuple en objetos individuales
(plantilla de función)
crea un tuple de referencias de reenvío
(plantilla de función)
(C++11)
crea un tuple concatenando cualquier número de tuples
(plantilla de función)
(C++17)
llama a una función con un tuple de argumentos
(plantilla de función)