std::tuple<Types...>::tuple
Defined in header <tuple>
|
||
constexpr tuple(); |
(1) | (since C++11) (conditionally explicit) |
tuple( const Types&... args ); |
(2) | (since C++11) (constexpr since C++14) (conditionally explicit) |
template< class... UTypes > tuple( UTypes&&... args ); |
(3) | (since C++11) (constexpr since C++14) (conditionally explicit) |
template< class... UTypes > tuple( const tuple<UTypes...>& other ); |
(4) | (since C++11) (constexpr since C++14) (conditionally explicit) |
template <class... UTypes> tuple( tuple<UTypes...>&& other ); |
(5) | (since C++11) (constexpr since C++14) (conditionally explicit) |
template< class U1, class U2 > tuple( const pair<U1,U2>& p ); |
(6) | (since C++11) (constexpr since C++14) (conditionally explicit) |
template< class U1, class U2 > tuple( pair<U1,U2>&& p ); |
(7) | (since C++11) (constexpr since C++14) (conditionally explicit) |
tuple( const tuple& other ) = default; |
(8) | (since C++11) |
tuple( tuple&& other ) = default; |
(9) | (since C++11) |
template< class Alloc > tuple( std::allocator_arg_t, const Alloc& a ); |
(10) | (since C++11) (constexpr since C++20) |
template< class Alloc > tuple( std::allocator_arg_t, const Alloc& a, |
(11) | (since C++11) (constexpr since C++20) (conditionally explicit) |
template< class Alloc, class... UTypes > tuple( std::allocator_arg_t, const Alloc& a, |
(12) | (since C++11) (constexpr since C++20) (conditionally explicit) |
template <class Alloc, class... UTypes> tuple( std::allocator_arg_t, const Alloc& a, |
(13) | (since C++11) (constexpr since C++20) (conditionally explicit) |
template< class Alloc, class... UTypes > tuple( std::allocator_arg_t, const Alloc& a, |
(14) | (since C++11) (constexpr since C++20) (conditionally explicit) |
template< class Alloc, class U1, class U2 > tuple( std::allocator_arg_t, const Alloc& a, |
(15) | (since C++11) (constexpr since C++20) (conditionally explicit) |
template< class Alloc, class U1, class U2 > tuple( std::allocator_arg_t, const Alloc& a, |
(16) | (since C++11) (constexpr since C++20) (conditionally explicit) |
template< class Alloc > tuple( std::allocator_arg_t, const Alloc& a, |
(17) | (since C++11) (constexpr since C++20) |
template< class Alloc > tuple( std::allocator_arg_t, const Alloc& a, |
(18) | (since C++11) (constexpr since C++20) |
Constructs a new tuple.
i
Ti
is not implicitly default-constructible for at least one i
.i
.i
.i
.i
in sizeof...(UTypes), initializes ith element of the tuple with std::get<i>(other).sizeof...(Types) == sizeof...(UTypes) and
std::is_constructible_v<Ti, const Ui&> is true for all i
and
sizeof...(Types) != 1 or
Types...
expands to T
and UTypes...
expands to U
) std::is_convertible_v<const tuple<U>&, T>, std::is_constructible_v<T, const tuple<U>&>, and std::is_same_v<T, U> are all false
.i
.i
in sizeof...(UTypes), initializes ith element of the tuple with std::forward<Ui>(std::get<i>(other)).sizeof...(Types) == sizeof...(UTypes) and
std::is_constructible_v<Ti, Ui&&> is true for all i
and
sizeof...(Types) != 1 or
Types...
expands to T
and UTypes...
expands to U
) std::is_convertible_v<tuple<U>, T>, std::is_constructible_v<T, tuple<U>>, and std::is_same_v<T, U> are all false
.i
.p.first
and the second element from p.second
other
.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 tuple |
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 make it possible to construct a tuple in copy-initialization context using list-initialization syntax:
std::tuple<int, int> foo_tuple() { return {1, -1}; // Error before N4387 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:
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
Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
N4387 | C++11 | some constructors were explicit, preventing useful behavior | most constructors made conditionally-explicit |
LWG 2510 | C++11 | default constructor was implicit | made conditionally-explicit |
Example
#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); }
Possible output:
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) |