Defined in header <tuple> | ||
---|---|---|
template< class T, class Tuple > constexpr T make_from_tuple( Tuple&& t ); | (since C++17) (until C++23) | |
template< class T, tuple-like Tuple > constexpr T make_from_tuple( Tuple&& t ); | (since C++23) |
Construct an object of type T
, using the elements of the tuple t
as the arguments to the constructor.
Given the exposition-only function make-from-tuple-impl
defined as follows: template<class T, tuple-like Tuple, std::size_t... I> // no constraint on Tuple before C++23
constexpr T make-from-tuple-impl(Tuple&& t, std::index_sequence<I...>) // exposition only
{
return T(std::get<I>(std::forward<Tuple>(t))...);
}
The effect is equivalent to return make-from-tuple-impl<T>(
.
std::forward<Tuple>(t),
std::make_index_sequence<std::tuple_size_v<
std::remove_reference_t<Tuple>>>{});
If std::tuple_size_v<std::remove_reference_t<Tuple>>
is 1
and.
| (since C++23) |
std::is_constructible_v<T, decltype(std::get<I>(std::declval<Tuple>()))...>
is false
, the program is ill-formed.
t | - | tuple whose elements to be used as arguments to the constructor of T |
The constructed T
object or reference.
| (until C++23) |
| (since C++23) |
Due to guaranteed copy elision, T
need not be movable.
Feature-test macro | Value | Std | Comment |
---|---|---|---|
__cpp_lib_make_from_tuple | 201606L | (C++17) |
std::make_from_tuple |
#include <iostream> #include <tuple> struct Foo { Foo(int first, float second, int third) { std::cout << first << ", " << second << ", " << third << '\n'; } }; int main() { auto tuple = std::make_tuple(42, 3.14f, 0); std::make_from_tuple<Foo>(std::move(tuple)); }
Output:
42, 3.14, 0
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 3528 | C++17 | cast containing reinterpret_cast etc. was allowed in the case of 1-tuple | prohibited |
(C++11) | creates a tuple object of the type defined by the argument types (function template) |
(C++11) | creates a tuple of forwarding references (function template) |
(C++17) | calls a function with a tuple of arguments (function template) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/utility/make_from_tuple