std::tuple_cat
来自cppreference.com
在标头 <tuple> 定义 | ||
template<class... Tuples> std::tuple</* CTypes */...> tuple_cat( Tuples&&... args); | (C++11 起) (C++14 前) | |
template<class... Tuples> constexprstd::tuple</* CTypes */...> tuple_cat( Tuples&&... args); | (C++14 起) (C++23 前) | |
template< tuple-like... Tuples> constexprstd::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> // 打印任意大小元组的辅助函数template<class Tuple, std::size_t N>struct TuplePrinter {staticvoid print(const Tuple& t){ TuplePrinter<Tuple, N -1>::print(t);std::cout<<", "<<std::get<N-1>(t);}}; template<class Tuple>struct TuplePrinter<Tuple, 1>{staticvoid print(const Tuple& t){std::cout<<std::get<0>(t);}}; template<typename... Args, std::enable_if_t<sizeof...(Args)==0, int>=0>void print(conststd::tuple<Args...>& t){std::cout<<"()\n";} template<typename... Args, std::enable_if_t<sizeof...(Args)!=0, int>=0>void print(conststd::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 =42; print(t2);}
输出:
(10, Test, 3.14, Foo, bar, 10, Test, 3.14, 42)
[编辑]参阅
(C++11) | 创建一个 tuple 对象,其类型根据各实参类型定义 (函数模板) |
(C++11) | 创建左值引用的 tuple,或将元组解包为独立对象 (函数模板) |
(C++11) | 创建转发引用的 tuple (函数模板) |