std::tuple_cat
| Definiert in der Header-Datei <tuple> |
||
| (seit C++11) (bis C++14) |
||
| (seit C++14) (bis C++23) |
||
| template< tuple-like... Tuples > constexpr std::tuple</* CTypes */...> tuple_cat( Tuples&&... args ); |
(seit C++23) | |
Konstruiert ein Tupel, das die Konkatenation aller Tupel in args darstellt. Die Elementtypen /* CTypes */ des zurückgegebenen Tupels werden durch die Konkatenation der Elementtyp-Pakete aller std::tuple(bis C++23)tuple-like(seit C++23) Typen in Tuples in der angegebenen Reihenfolge gebildet.
|
Das Verhalten ist undefiniert, wenn irgendein Typ in std::decay_t<Tuples>... keine Spezialisierung von std::tuple ist. Eine Implementierung kann jedoch wählen, Typen (wie std::array und std::pair) zu unterstützen, die dem Tupel-ähnlichen Protokoll folgen. |
(bis C++23) |
|
Die Typen std::decay_t<Tuples>... sind auf Tupel-ähnlich beschränkt, d.h. jeder darin enthaltene Typ muss eine Spezialisierung von std::tuple oder ein anderer Typ (wie std::array und std::pair) sein, der |
(seit C++23) |
Wenn irgendein Typ in /* CTypes */ nicht aus dem Typ des entsprechenden Elements in der aus args konkatenierten Elementsequenz konstruierbar ist, ist das Verhalten undefiniert(bis C++23)ist das Programm fehlerhaft(seit C++23).
Inhalt |
[edit] Parameter
| args | - | Null oder mehr Tupel, die konkateniert werden sollen |
[edit] Rückgabewert
Ein std::tuple-Objekt, das aus allen Elementen aller Argumenttupel besteht und aus std::get<j>(std::forward<Ti>(arg)) für jedes einzelne Element konstruiert wurde.
[edit] Beispiel
#include <iostream> #include <string> #include <tuple> // helper function to print a tuple of any size 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"; } // end helper function 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); }
Ausgabe
(10, Test, 3.14, Foo, bar, 10, Test, 3.14, 42)
[edit] Siehe auch
| (C++11) |
erstellt ein tuple-Objekt vom Typ, der durch die Argumenttypen definiert ist(function template) |
| (C++11) |
erstellt ein tuple von Lvalue-Referenzen oder entpackt ein Tupel in einzelne Objekte (Funktionsvorlage) |
| (C++11) |
erstellt ein tuple aus Forwarding-Referenzen(function template) |