std::make_from_tuple

来自cppreference.com
< cpp‎ | utility
 
 
工具库
语言支持
类型支持(基本类型、RTTI)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
变参数函数
调试支持
(C++26)
三路比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
make_from_tuple
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)

 
在标头 <tuple> 定义
template< class T, class Tuple >
constexpr T make_from_tuple( Tuple&& t );
(C++17 起)
(C++23 前)
template< class T, tuple-like Tuple >
constexpr T make_from_tuple( Tuple&& t );
(C++23 起)

以元组 t 的各元素作为构造函数的实参构造 T 类型的对象。

给定如下定义的仅用于阐述的函数 /*make-from-tuple-impl*/ template<class T, tuple-like Tuple, std::size_t... I> // C++23 前没有约束 Tuple
constexpr T /*make-from-tuple-impl*/(Tuple&& t, std::index_sequence<I...>)
{
    return T(std::get<I>(std::forward<Tuple>(t))...);
}

效果等价于:
return /*make-from-tuple-impl*/<T>(
    std::forward<Tuple>(t),
    std::make_index_sequence<std::tuple_size_v<std::remove_reference_t<Tuple>>>{}
);

如果

(C++23 起)

那么程序非良构。

参数

t - 元素被用作 T 构造函数的实参的元组

返回值

构造的 T 对象或引用。

注解

Tuple 不必是 std::tuple,它可以被任何支持 std::getstd::tuple_size 的类型替代;特别是可以用 std::arraystd::pair

(C++23 前)

Tuple 被约束为元组式类型,即其中每个类型都必须是 std::tuple 的特化,或者实现了 tuple-like 的其他任何类型(例如 std::arraystd::pair)。

(C++23 起)

因为受保证的复制消除T 不需要可移动。

功能特性测试 标准 功能特性
__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));
}

输出:

42, 3.14, 0

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 3528 C++17 在一元组的情况下允许含有 reinterpret_cast 等的转型 已禁止

参阅

创建一个 tuple 对象,其类型根据各实参类型定义
(函数模板)
创建转发引用tuple
(函数模板)
(C++17)
以一个实参的元组来调用函数
(函数模板)