Namespaces
Variants

std:: tuple_element <std::tuple>

From cppreference.net
Utilities library
Défini dans l'en-tête <tuple>
template < std:: size_t I, class ... Types >
struct tuple_element < I, std:: tuple < Types... > > ;
(depuis C++11)

Fournit un accès indexé à la compilation aux types des éléments du tuple.

Table des matières

Types membres

Type Définition
type le type du I ème élément du tuple, où I est dans [ 0 , sizeof... ( Types ) )

Implémentation possible

template<std::size_t I, class T>
struct tuple_element;
#ifndef __cpp_pack_indexing
// cas récursif
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...>>
{ };
// cas de base
template<class Head, class... Tail>
struct tuple_element<0, std::tuple<Head, Tail...>>
{
    using type = Head;
};
#else
// implémentation C++26 utilisant l'indexation de paquets
template<std::size_t I, class... Ts>
struct tuple_element<I, std::tuple<Ts...>>
{
    using type = Ts...[I];
};
#endif

Exemple

#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 << "  Le type à l'index " << I << " est : "
                  << 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>();
}

Sortie possible :

std::tuple<int, long&, char const&, bool&&, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >, MyStruct volatile>
  Le type à l'index 0 est : int
  Le type à l'index 1 est : long&
  Le type à l'index 2 est : char const&
  Le type à l'index 3 est : bool&&
  Le type à l'index 4 est : std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >
  Le type à l'index 5 est : MyStruct volatile
std::pair<char, bool&&>
  Le type à l'index 0 est : char
  Le type à l'index 1 est : bool&&

Voir aussi

Liaison structurée (C++17) lie les noms spécifiés aux sous-objets ou éléments de tuple de l'initialiseur
obtient les types d'éléments d'un type similaire à un tuple
(modèle de classe)