std::tuple_cat
来自cppreference.com
在标头 <tuple> 定义
|
||
template< class... Tuples > std::tuple</* CTypes */...> tuple_cat( Tuples&&... args ); |
(C++11 起) (C++14 前) |
|
template< class... Tuples > constexpr std::tuple</* CTypes */...> tuple_cat( Tuples&&... args ); |
(C++14 起) (C++23 前) |
|
template< tuple-like... Tuples > constexpr std::tuple</* CTypes */...> tuple_cat( Tuples&&... args ); |
(C++23 起) | |
构造以 args 中的所有元组所拼接成的元组。返回的元组的元素类型 /* CTypes */ 通过将 Tuples
中的每个 std::tuple (C++23 前)tuple-like
(C++23 起) 类型的元素类型包拼接得到。
std::decay_t<Tuples>... 中的有类型不是 std::tuple 的特化时行为未定义。然而,实现可以选择支持遵循仿元组协议的类型(例如 std::array 和 std::pair)。 |
(C++23 前) |
std::decay_t<Tuples>... 中的各类型被约束为元组式类型,即其中每个类型都必须是 std::tuple 的特化,或者实现了 |
(C++23 起) |
如果 /* CTypes */ 中有任何元素无法从以 args 中的所有元组的所有元素拼接得到的元素序列中对应的元素的类型构造,那么行为未定义 (C++23 前)程序非良构 (C++23 起)。
参数
args | - | 要拼接的零或更多个元组 |
返回值
std::tuple 对象,由所有参数元组的所有元素组成,对于每个独立元素构造自 std::get<i>(std::forward<Ti>(arg))。
示例
运行此代码
#include <iostream> #include <string> #include <tuple> // 打印任何大小 tuple 的辅助函数 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"; } // 辅助函数结束 int main() { std::tuple<int, std::string, float> t1(10, "Test", 3.14); int n = 7; auto t2 = std::tuple_cat(t1, std::make_tuple("Foo", "bar"), t1, std::tie(n)); n = 10; print(t2); }
输出:
(10, Test, 3.14, Foo, bar, 10, Test, 3.14, 10)
参阅
(C++11) |
创建一个 tuple 对象,其类型根据各实参类型定义 (函数模板) |
(C++11) |
创建左值引用的 tuple ,或将 tuple 解包为独立对象 (函数模板) |
(C++11) |
创建转发引用的 tuple (函数模板) |