std::tuple_element<std::tuple>

来自cppreference.com
< cpp‎ | utility‎ | tuple
 
 
工具库
语言支持
类型支持(基本类型、RTTI)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
变参数函数
调试支持
(C++26)
三路比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)

 
 
在标头 <tuple> 定义
template< std::size_t I, class... Types >
struct tuple_element< I, std::tuple<Types...> >;
(C++11 起)

提供对元组元素类型的编译时索引访问。

成员类型

成员类型 定义
type 元组的第 I 元素的类型,其中 I[0sizeof...(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 <cstddef>
#include <iostream>
#include <string>
#include <tuple>
#include <typeinfo>
#include <type_traits>
#include <utility>
 
namespace details
{
    template<class TupleLike, std::size_t I>
    void printTypeAtIndex()
    {
        std::cout << "  位于索引 " << I << " 的类型是: ";
        using SelectedType = std::tuple_element_t<I, TupleLike>;
        std::cout << typeid(SelectedType).name() << '\n';
    }
}
 
template<typename TupleLike, std::size_t I = 0>
void printTypes()
{
    if constexpr (I == 0)
        std::cout << typeid(TupleLike).name() << '\n';
 
    if constexpr (I < std::tuple_size_v<TupleLike>)
    {
        details::printTypeAtIndex<TupleLike, I>();
        printTypes<TupleLike, I + 1>();
    }
}
 
struct MyStruct {};
 
using MyTuple = std::tuple<int, long, char, bool, std::string, MyStruct>;
 
using MyPair = std::pair<char, bool>;
 
static_assert
(
    std::is_same_v<std::tuple_element_t<0, MyPair>, char> &&
    std::is_same_v<std::tuple_element_t<1, MyPair>, bool>
);
 
int main()
{
    printTypes<MyTuple>();
    printTypes<MyPair>();
}

可能的输出:

St5tupleIJilcbNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE8MyStructEE
  位于索引 0 的类型是: i
  位于索引 1 的类型是: l
  位于索引 2 的类型是: c
  位于索引 3 的类型是: b
  位于索引 4 的类型是: NSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE
  位于索引 5 的类型是: 8MyStruct
St4pairIcbE
  位于索引 0 的类型是: c
  位于索引 1 的类型是: b

参阅

结构化绑定 (C++17) 绑定指定的名字到初始化式的子对象或元组元素
获得元组式类型的元素类型
(类模板)