Namespaces
Variants

std:: tuple_cat

From cppreference.net
Utilities library
Definido en el encabezado <tuple>
template < class ... Tuples >
std:: tuple < /* CTypes */ ... > tuple_cat ( Tuples && ... args ) ;
(desde C++11)
(hasta C++14)
template < class ... Tuples >
constexpr std:: tuple < /* CTypes */ ... > tuple_cat ( Tuples && ... args ) ;
(desde C++14)
(hasta C++23)
template < tuple - like... Tuples >
constexpr std:: tuple < /* CTypes */ ... > tuple_cat ( Tuples && ... args ) ;
(desde C++23)

Construye una tupla que es una concatenación de todas las tuplas en args . Los tipos de elementos /* CTypes */ de la tupla devuelta se forman concatenando los paquetes de tipos de elementos de todos los tipos std::tuple (until C++23) tuple-like (since C++23) en Tuples en orden.

El comportamiento es indefinido si algún tipo en std:: decay_t < Tuples > ... no es una especialización de std::tuple . Sin embargo, una implementación puede optar por admitir tipos (como std::array y std::pair ) que sigan el protocolo similar a tupla.

(hasta C++23)

Los tipos std:: decay_t < Tuples > ... están restringidos a ser similares a tuplas, es decir, se requiere que cada tipo sea una especialización de std::tuple u otro tipo (como std::array y std::pair ) que modele tuple-like .

(desde C++23)

Si algún tipo en /* CTypes */ no es construible a partir del tipo del elemento correspondiente en la secuencia de elementos concatenados desde args , el comportamiento es indefinido (hasta C++23) el programa está mal formado (desde C++23) .

Contenidos

Parámetros

args - cero o más tuplas para concatenar

Valor de retorno

Un objeto std::tuple compuesto por todos los elementos de todas las tuplas argumento construido a partir de std :: get < j > ( std:: forward < Ti > ( arg ) ) para cada elemento individual.

Ejemplo

#include <iostream>
#include <string>
#include <tuple>
// función auxiliar para imprimir una tupla de cualquier tamaño
template<class Tuple, std::size_t N>
struct TuplePrinter
{
    static void print(const Tuple& t)
    {
        TuplePrinter<Tuple, N - 1>::print(t);
        std::cout << ", " << std::get<N-1>(t);
    }
};
template<class Tuple>
struct TuplePrinter<Tuple, 1>
{
    static void print(const Tuple& t)
    {
        std::cout << std::get<0>(t);
    }
};
template<typename... Args, std::enable_if_t<sizeof...(Args) == 0, int> = 0>
void print(const std::tuple<Args...>& t)
{
    std::cout << "()\n";
}
template<typename... Args, std::enable_if_t<sizeof...(Args) != 0, int> = 0>
void print(const std::tuple<Args...>& t)
{
    std::cout << "(";
    TuplePrinter<decltype(t), sizeof...(Args)>::print(t);
    std::cout << ")\n";
}
// fin de la función auxiliar
int main()
{
    std::tuple<int, std::string, float> t1(10, "Test", 3.14);
    int n = 7;
    auto t2 = std::tuple_cat(t1, std::make_tuple("Foo", "bar"), t1, std::tie(n));
    n = 42;
    print(t2);
}

Salida:

(10, Test, 3.14, Foo, bar, 10, Test, 3.14, 42)

Véase también

(C++11)
crea un objeto tuple del tipo definido por los tipos de argumentos
(plantilla de funció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)