Udostępnij za pośrednictwem


tuple_element — Klasa

Opakowuje tuple element. Specjalizacje opakowuje array elementy i pair elementy.

Składnia

// CLASS tuple_element (find element by index)
template <size_t Index, class Tuple>
   struct tuple_element;

// tuple_element for const
template <size_t Index, class Tuple>
   struct tuple_element<Index, const Tuple>;

// tuple_element for volatile
template <size_t Index, class Tuple>
   struct tuple_element<Index, volatile Tuple>;

// tuple_element for const volatile
template <size_t Index, class Tuple>
   struct tuple_element<Index, const volatile Tuple>;

// Helper typedef
template <size_t Index, class Tuple>
   using tuple_element_t = typename tuple_element<Index, Tuple>::type;

// Specialization for arrays
template <size_t Index, class Elem, size_t Size>
   struct tuple_element<Index, array<Elem, Size>>;

// Specializations for pairs
// struct to determine type of element 0 in pair
template <class T1, class T2>
   struct tuple_element<0, pair<T1, T2>>;

// struct to determine type of element 1 in pair
template <class T1, class T2>
   struct tuple_element<1, pair<T1, T2>>;

Parametry

Indeks
Indeks wyznaczonego elementu.

Krotka
Typ krotki.

Elem
Typ elementu tablicy.

Rozmiar
Rozmiar tablicy.

T1
Typ pierwszego elementu w parze.

T2
Typ drugiego elementu w parze.

Uwagi

Szablon tuple_element klasy ma zagnieżdżoną definicję type typów, która jest synonimem typu indeksu indeksu krotki typu krotki.

Typedef tuple_element_t jest wygodnym aliasem dla elementu tuple_element<Index, Tuple>::type.

Specjalizacja szablonu klasy dla tablic udostępnia interfejs array jako krotkę Size elementów, z których każdy ma ten sam typ. Każda specjalizacja ma zagnieżdżoną definicję type typów, która jest synonimem typu indeksu elementu array, z dowolnymi kwalifikacjami const-volatile zachowanymi.

Specjalizacje szablonów dla pair typów zapewniają jedną definicję typu składowego, type, która jest synonimem typu elementu na określonej pozycji w parze, z dowolnymi kwalifikacjami const i/lub volatile zachowanymi. Typedef tuple_element_t jest wygodnym aliasem dla elementu tuple_element<N, pair<T1, T2>>::type.

get Funkcja służy do zwracania elementu na określonej pozycji lub określonego typu.

Przykład: pobieranie elementu z krotki

#include <tuple>
#include <string>
#include <iostream>

using namespace std;
typedef tuple<int, double, string> MyTuple;

int main() {
    MyTuple c0{ 0, 1.5, "Tail" };

    tuple_element_t<0, MyTuple> val = get<0>(c0); //get by index
    tuple_element_t<1, MyTuple> val2 = get<1>(c0);
    tuple_element_t<2, MyTuple> val3 = get<string>(c0); // get by type

    cout << val << " " << val2 << " " << val3 << endl;
}
0 1.5 Tail

Przykład: pobieranie elementu z tablicy

#include <array>
#include <iostream>

using namespace std;
typedef array<int, 4> MyArray;

int main()
{
    MyArray c0 { 0, 1, 2, 3 };

    for (const auto& e : c0)
    {
        cout << e << " ";
    }
    cout << endl;

    // display first element "0"
    tuple_element<0, MyArray>::type val = c0.front();
    cout << val << endl;
}
0 1 2 3
0

Przykład: pobieranie elementu z pary

#include <utility>
#include <iostream>

using namespace std;

typedef pair<int, double> MyPair;
int main() {
    MyPair c0(0, 1.333);

    // display contents "0 1"
    cout << get<0>(c0) << " ";
    cout << get<1>(c0) << endl;

    // display first element "0 " by index
    tuple_element<0, MyPair>::type val = get<0>(c0);
    cout << val << " ";

    // display second element by type
    tuple_element<1, MyPair>::type val2 = get<double>(c0);
    cout << val2 << endl;
}
0 1.333
0 1.333

Wymagania

Nagłówek:<krotka>

Header:<array> (dla specjalizacji tablicy)

Header:<utility> (dla specjalizacji par)

Przestrzeń nazw: std