Namespaces
Variants

std:: tuple_element <std::array>

From cppreference.net
Definiert im Header <array>
template < std:: size_t I, class T, std:: size_t N >
struct tuple_element < I, std:: array < T, N > > ;
(seit C++11)

Bietet kompilierzeitlichen indexbasierten Zugriff auf den Typ der Elemente des Arrays über eine tupelartige Schnittstelle.

Inhaltsverzeichnis

Mitgliedertypen

Membertyp Definition
type der Typ der Elemente des Arrays

Mögliche Implementierung

template<std::size_t I, class T>
struct tuple_element;
template<std::size_t I, class T, std::size_t N>
struct tuple_element<I, std::array<T,N>>
{
    using type = T;
};

Beispiel

#include <array>
#include <tuple>
#include <type_traits>
int main()
{
    // Array definieren und Typ des Elements an Position 0 ermitteln
    std::array<int, 10> data{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
    using T = std::tuple_element<0, decltype(data)>::type; // int
    static_assert(std::is_same_v<T, int>);
    const auto const_data = data;
    using CT = std::tuple_element<0, decltype(const_data)>::type; // const int
    // Das Ergebnis von tuple_element hängt von der CV-Qualifikation des tuple-ähnlichen Typs ab
    static_assert(!std::is_same_v<T, CT>);
    static_assert(std::is_same_v<CT, const int>);
}

Siehe auch

Structured binding (C++17) bindet die angegebenen Namen an Teilobjekte oder Tupel-Elemente des Initialisierers
ermittelt den Typ des angegebenen Elements
(Klassen-Template-Spezialisierung)
ermittelt den Typ der Elemente von pair
(Klassen-Template-Spezialisierung)