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