Namensräume
Varianten
Aktionen

std::make_from_tuple

Von cppreference.com
< cpp‎ | utility
 
 
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)
Ganzzahl-Vergleichsfunktionen
(C++20)(C++20)(C++20)  
(C++20)
Swap und Typ-Operationen
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Gemeinsame Vokabulartypen
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
make_from_tuple
(C++17)
(C++23)



 
Definiert in der Header-Datei <tuple>
template< class T, class Tuple >
constexpr T make_from_tuple( Tuple&& t );
(seit C++17)
(bis C++23)
template< class T, tuple-like Tuple >
constexpr T make_from_tuple( Tuple&& t );
(seit C++23)

Erzeugt ein Objekt vom Typ T, wobei die Elemente des Tupels t als Argumente für den Konstruktor verwendet werden.

Gegeben die expositions-only Funktion /*make-from-tuple-impl*/, die wie folgt definiert ist:
template<class T, tuple-like Tuple, std::size_t... I> // Kein Constraint für Tuple vor C++23
constexpr T /*make-from-tuple-impl*/(Tuple&& t, std::index_sequence<I...>)
{
    return T(std::get<I>(std::forward<Tuple>(t))...);
}

Die Wirkung ist äquivalent zu
return /*make-from-tuple-impl*/<T>(
    std::forward<Tuple>(t),
    std::make_index_sequence<std::tuple_size_v<std::remove_reference_t<Tuple>>>{}
);
.

Wenn

(seit C++23)

ist das Programm fehlerhaft.

Inhalt

[edit] Parameter

t - Tupel, dessen Elemente als Argumente für den Konstruktor von T verwendet werden sollen

[edit] Rückgabewert

Das erzeugte T-Objekt oder eine Referenz darauf.

[edit] Hinweise

Tuple muss nicht std::tuple sein, sondern kann alles sein, was std::get und std::tuple_size unterstützt; insbesondere können std::array und std::pair verwendet werden.

(bis C++23)

Tuple ist auf tuple-ähnlich beschränkt, d.h. jeder Typ darin muss eine Spezialisierung von std::tuple oder ein anderer Typ (wie std::array und std::pair) sein, der tuple-like modelliert.

(seit C++23)

Aufgrund der garantierten Copy Elision muss T nicht verschiebbar sein.

Feature-Test-Makro Wert Std Feature
__cpp_lib_make_from_tuple 201606L (C++17) std::make_from_tuple

[edit] Beispiel

#include <iostream>
#include <tuple>
 
struct Foo
{
    Foo(int first, float second, int third)
    {
        std::cout << first << ", " << second << ", " << third << '\n';
    }
};
 
int main()
{
    auto tuple = std::make_tuple(42, 3.14f, 0);
    std::make_from_tuple<Foo>(std::move(tuple));
}

Ausgabe

42, 3.14, 0

[edit] Defect Reports

Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR angewendet auf Verhalten wie veröffentlicht Korrigiertes Verhalten
LWG 3528 C++17 cast mit reinterpret_cast etc. war im Fall eines 1-Tupels erlaubt verboten

[edit] Siehe auch

erstellt ein tuple-Objekt vom Typ, der durch die Argumenttypen definiert ist
(function template) [bearbeiten]
erstellt ein tuple aus Forwarding-Referenzen
(function template) [bearbeiten]
(C++17)
ruft eine Funktion mit einem Tupel von Argumenten auf
(Funktionsvorlage) [edit]