Defined in header <tuple> | ||||
---|---|---|---|---|
| (1) | (since C++11) | ||
| (2) | (since C++11) (until C++14) | ||
| (2) | (since C++14) | ||
| (3) | (since C++11) (until C++14) | ||
| (3) | (since C++14) | ||
| (4) | (since C++11) (until C++14) | ||
| (4) | (since C++14) | ||
| (5) | (since C++11) (until C++14) | ||
| (5) | (since C++14) | ||
| (6) | (since C++11) (until C++14) | ||
| (6) | (since C++14) | ||
| (7) | (since C++11) (until C++14) | ||
| (7) | (since C++14) | ||
| (8) | (since C++11) | ||
| (9) | (since C++11) | ||
| (10) | (since C++11) | ||
| (11) | (since C++11) | ||
| (12) | (since C++11) | ||
| (13) | (since C++11) | ||
| (14) | (since C++11) | ||
| (15) | (since C++11) | ||
| (16) | (since C++11) | ||
| (17) | (since C++11) | ||
| (18) | (since C++11) |
Constructs a new tuple.
1) Default constructor. Value-initializes all elements.
(until C++17) | |
This constructor does not participate in overload resolution unless std::is_default_constructible<Ti>::value is true for all i | (since C++17) |
2) Direct constructor. Initializes each element of the tuple with the corresponding parameter.
This constructor does not participate in overload resolution unless
sizeof...(Types) >= 1
and std::is_copy_constructible<Ti>::value
is true
for all i
. This constructor is explicit if and only if std::is_convertible<const Ti&, Ti>::value is false for at least one i . | (since C++17) |
3) Converting constructor. Initializes each element of the tuple with the corresponding value in
std::forward<Utypes>(args)
. Requires that
sizeof...(Types) == sizeof...(UTypes).
This constructor shall not participate in overload resolution unless
sizeof...(Types) >= 1
and std::is_constructible<Ti, Ui&&>::value
is true
for all i
. The constructor is explicit if and only if std::is_convertible<Ui&&, Ti>::value is false for at least one i . | (since C++17) |
4) Converting copy-constructor. For all
i
in sizeof...(UTypes)
, initializes ith element of the tuple with std::get<i>(other)
. Requires that
sizeof...(Types) == sizeof...(UTypes)
Does not participate in overload resolution unless
std::is_constructible<Ti, const Ui&>::value
is true
for all i
. The constructor is explicit if and only if std::is_convertible<const Ui&, Ti>::value is false for at least one i . | (since C++17) |
5) Converting move-constructor. For all
i
in sizeof...(UTypes)
, initializes ith element of the tuple with std::forward<Ui>(std::get<i>(other))
. Requires that
sizeof...(Types) == sizeof...(UTypes)
Does not participate in overload resolution unless
std::is_constructible<Ti, Ui&&>::value
is true
for all i
. The constructor is explicit if and only if std::is_convertible<Ui&&, Ti>::value is false for at least one i . | (since C++17) |
6) Pair copy constructor. Constructs a 2-element tuple with the first element constructed from
p.first
and the second element from p.second
Requires that
sizeof...(Types) == 2
Does not participate in overload resolution unless
std::is_constructible<T0,const U1&>::value
and std::is_constructible<T1, const U2&>::value
are both true
The constructor is explicit if and only if std::is_convertible<const U1&, T0>::value or std::convertible<const U2&, T1>::value is false | (since C++17) |
7) Pair move constructor. Constructs a 2-element tuple with the first element constructed from
std::forward<U1>(p.first)
and the second element from std::forward<U2>(p.second)
Requires that
sizeof...(Types) == 2
Does not participate in overload resolution unless
std::is_constructible<T0, U1&&>::value
and std::is_constructible<T1, U2&&>::value
are both true
The constructor is explicit if and only if std::is_convertible<U1&&, T0>::value or std::convertible<U2&&, T1>::value is false | (since C++17) |
8) Implicitly-defined copy constructor. Initializes each element of the tuple with the corresponding element of
other
. This constructor is
constexpr
if every operation it performs is constexpr
. For the empty tuple std::tuple<>
, it is constexpr
. 9) Implicitly-defined move constructor. Initializes each ith element of the tuple with
std::forward<Ui>(std::get<i>(other))
. This constructor is
constexpr
if every operation it performs is constexpr
. For the empty tuple std::tuple<>
, it is constexpr
. 10-18) Identical to (1-9) except each element is created by uses-allocator construction, that is, the Allocator object
a
is passed as an additional argument to the constructor of each element for which std::uses_allocator<Ui, Alloc>::value
is true
.Parameters
args | - | values used to initialize each element of the tuple |
other | - | a tuple of values used to initialize each element of the tupe |
p | - | pair of values used to initialize both elements of this 2-tuple |
a | - | allocator to use in uses-allocator construction |
Notes
Conditionally-explicit constructors in C++17 make it possible to construct a tuple in copy-initialization context using list-initialization syntax:
1 2 3 4 5 | std::tuple< int , int > foo_tuple() { return {1, -1}; // Error until C++17 return std::make_tuple(1, -1); // Always works } |
Note that if some element of the list is not implicitly convertible to the corresponding element of the target tuple, the constructors become explicit.
1 2 3 4 5 6 | using namespace std::chrono; void launch_rocket_at(std::tuple<hours, minutes, seconds>); launch_rocket_at({hours(1), minutes(2), seconds(3)}); // OK launch_rocket_at({1, 2, 3}); // Error: int is not implicitly convertible to duration launch_rocket_at(std::tuple<hours, minutes, seconds>{1, 2, 3}); // OK |
Example
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 | #include <iostream> #include <string> #include <vector> #include <tuple> #include <memory> // helper function to print a tuple of any size template < class Tuple, std:: size_t N> struct TuplePrinter { static void print( const Tuple& t) { TuplePrinter<Tuple, N-1>::print(t); std::cout << ", " << std::get<N-1>(t); } }; template < class Tuple> struct TuplePrinter<Tuple, 1>{ static void print( const Tuple& t) { std::cout << std::get<0>(t); } }; template < class ... Args> void print( const std::tuple<Args...>& t) { std::cout << "(" ; TuplePrinter<decltype(t), sizeof ...(Args)>::print(t); std::cout << ")\n" ; } // end helper function int main() { std::tuple< int , std::string, double > t1; std::cout << "Value-initialized: " ; print(t1); std::tuple< int , std::string, double > t2(42, "Test" , -3.14); std::cout << "Initialized with values: " ; print(t2); std::tuple< char , std::string, int > t3(t2); std::cout << "Implicitly converted: " ; print(t3); std::tuple< int , double > t4(std::make_pair(42, 3.14)); std::cout << "Constructed from a pair" ; print(t4); // given Allocator my_alloc with a single-argument constructor my_alloc(int) // use my_alloc(1) to allocate 10 ints in a vector std::vector< int , my_alloc> v(10, 1, my_alloc(1)); // use my_alloc(2) to allocate 10 ints in a vector in a tuple std::tuple< int , std::vector< int , my_alloc>, double > t5(std::allocator_arg, my_alloc(2), 42, v, -3.14); } |
Output:
1 2 3 4 | Value-initialized: (0, , 0) Initialized with values: (42, Test, -3.14) Implicitly converted: (*, Test, -3) Constructed from a pair(42, 3.14) |
See also
creates a tuple object of the type defined by the argument types (function template) | |
creates a tuple of lvalue references or unpacks a tuple into individual objects (function template) | |
creates a tuple of rvalue references (function template) |
Please login to continue.