|
|
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 typeT
, using the elements of the tuplet 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...>){
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
| (since C++23) |
the program is ill-formed.
Contents |
t | - | tuple whose elements to be used as arguments to the constructor ofT |
The constructedT
object or reference.
| (until C++23) |
| (since C++23) |
Due toguaranteed copy elision,T
need not be movable.
Feature-test macro | Value | Std | Feature |
---|---|---|---|
__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 containingreinterpret_cast etc. was allowed in the case of 1-tuple | prohibited |
(C++11) | creates atuple object of the type defined by the argument types(function template)[edit] |
(C++11) | creates atuple offorwarding references(function template)[edit] |
(C++17) | calls a function with a tuple of arguments (function template)[edit] |