Namespaces
Variants

std:: make_tuple

From cppreference.net
Utilities library
Défini dans l'en-tête <tuple>
template < class ... Types >
std:: tuple < VTypes... > make_tuple ( Types && ... args ) ;
(depuis C++11)
(constexpr depuis C++14)

Crée un objet tuple, en déduisant le type cible à partir des types des arguments.

Pour chaque Ti dans Types... , le type correspondant Vi dans VTypes... est std:: decay < Ti > :: type sauf si l'application de std::decay donne std:: reference_wrapper < X > pour un certain type X , auquel cas le type déduit est X& .

Table des matières

Paramètres

args - zéro ou plusieurs arguments pour construire le tuple

Valeur de retour

Un objet std::tuple contenant les valeurs données, créé comme si par std:: tuple < VTypes... > ( std:: forward < Types > ( t ) ... ) .

Implémentation possible

template <class T>
struct unwrap_refwrapper
{
    using type = T;
};
template <class T>
struct unwrap_refwrapper<std::reference_wrapper<T>>
{
    using type = T&;
};
template <class T>
using unwrap_decay_t = typename unwrap_refwrapper<typename std::decay<T>::type>::type;
// ou utiliser std::unwrap_ref_decay_t (depuis C++20)
template <class... Types>
constexpr // depuis C++14
std::tuple<unwrap_decay_t<Types>...> make_tuple(Types&&... args)
{
    return std::tuple<unwrap_decay_t<Types>...>(std::forward<Types>(args)...);
}

Exemple

#include <iostream>
#include <tuple>
#include <functional>
std::tuple<int, int> f() // cette fonction retourne plusieurs valeurs
{
    int x = 5;
    return std::make_tuple(x, 7); // return {x,7}; en C++17
}
int main()
{
    // construction de tuple hétérogène
    int n = 1;
    auto t = std::make_tuple(10, "Test", 3.14, std::ref(n), n);
    n = 7;
    std::cout << "La valeur de t est ("
              << std::get<0>(t) << ", "
              << std::get<1>(t) << ", "
              << std::get<2>(t) << ", "
              << std::get<3>(t) << ", "
              << std::get<4>(t) << ")\n";
    // fonction retournant plusieurs valeurs
    int a, b;
    std::tie(a, b) = f();
    std::cout << a << ' ' << b << '\n';
}

Sortie :

The value of t is (10, Test, 3.14, 7, 1)
5 7

Voir aussi

(C++11)
crée un tuple de références de lvalue ou décompose un tuple en objets individuels
(modèle de fonction)
crée un tuple de références de transfert
(modèle de fonction)
(C++11)
crée un tuple en concaténant un nombre quelconque de tuples
(modèle de fonction)
(C++17)
appelle une fonction avec un tuple d'arguments
(modèle de fonction)