Namensräume
Varianten
Aktionen

std::tuple_cat

Von cppreference.com
< cpp‎ | utility‎ | tuple
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
 
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 tuple-like modelliert.

(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

erstellt ein tuple-Objekt vom Typ, der durch die Argumenttypen definiert ist
(function template) [bearbeiten]
(C++11)
erstellt ein tuple von Lvalue-Referenzen oder entpackt ein Tupel in einzelne Objekte
(Funktionsvorlage) [edit]
erstellt ein tuple aus Forwarding-Referenzen
(function template) [bearbeiten]