std:: tuple_cat
|
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
|
(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) |
|
(C++11)
|
crea un
tuple
de
referencias de reenvío
(plantilla de función) |