std:: tuple_element <std::tuple>
From cppreference.net
C++
Utilities library
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
std::tuple
| Member functions | ||||
| Non-member functions | ||||
|
(until C++20)
(until C++20)
(until C++20)
(until C++20)
(until C++20)
(C++20)
|
||||
| Helper concepts | ||||
|
(C++23)
|
||||
| Helper classes | ||||
|
tuple_element
<std::tuple>
|
||||
|
(C++23)
|
||||
|
(C++23)
|
||||
| Deduction guides (C++17) |
|
Определено в заголовочном файле
<tuple>
|
||
|
template
<
std::
size_t
I,
class
...
Types
>
struct tuple_element < I, std:: tuple < Types... > > ; |
(начиная с C++11) | |
Обеспечивает доступ к типам элементов кортежа по индексу на этапе компиляции.
Содержание |
Типы членов
| Тип | Определение |
| type |
тип
I
-го
элемента кортежа, где
I
находится в диапазоне
[
0
,
sizeof...
(
Types
)
)
|
Возможная реализация
template<std::size_t I, class T> struct tuple_element; #ifndef __cpp_pack_indexing // рекурсивный случай template<std::size_t I, class Head, class... Tail> struct tuple_element<I, std::tuple<Head, Tail...>> : std::tuple_element<I - 1, std::tuple<Tail...>> { }; // базовый случай template<class Head, class... Tail> struct tuple_element<0, std::tuple<Head, Tail...>> { using type = Head; }; #else // реализация C++26 с использованием индексации пакетов template<std::size_t I, class... Ts> struct tuple_element<I, std::tuple<Ts...>> { using type = Ts...[I]; }; #endif |
Пример
Запустить этот код
#include <boost/type_index.hpp> #include <cstddef> #include <iostream> #include <string> #include <tuple> #include <utility> template<typename TupleLike, std::size_t I = 0> void printTypes() { if constexpr (I == 0) std::cout << boost::typeindex::type_id_with_cvr<TupleLike>() << '\n'; if constexpr (I < std::tuple_size_v<TupleLike>) { using SelectedType = std::tuple_element_t<I, TupleLike>; std::cout << " Тип по индексу " << I << ": " << boost::typeindex::type_id_with_cvr<SelectedType>() << '\n'; printTypes<TupleLike, I + 1>(); } } struct MyStruct {}; using MyTuple = std::tuple<int, long&, const char&, bool&&, std::string, volatile MyStruct>; using MyPair = std::pair<char, bool&&>; static_assert(std::is_same_v<std::tuple_element_t<0, MyPair>, char>); static_assert(std::is_same_v<std::tuple_element_t<1, MyPair>, bool&&>); int main() { printTypes<MyTuple>(); printTypes<MyPair>(); }
Возможный вывод:
std::tuple<int, long&, char const&, bool&&, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >, MyStruct volatile> The type at index 0 is: int The type at index 1 is: long& The type at index 2 is: char const& The type at index 3 is: bool&& The type at index 4 is: std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > The type at index 5 is: MyStruct volatile std::pair<char, bool&&> The type at index 0 is: char The type at index 1 is: bool&&
Смотрите также
| Structured binding (C++17) | связывает указанные имена с подобъектами или элементами кортежа инициализатора |
|
(C++11)
|
получает типы элементов кортежеподобного типа
(шаблон класса) |