命名空间
变体
操作

std::tuple_cat

来自 cppreference.cn
< cpp‎ | utility‎ | tuple
 
 
工具库
通用工具
函数对象
位操作 (C++20 起)
(C++11)
关系运算符 (C++20 中已弃用)
整数比较函数
(C++20 起)(C++20 起)(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)
(C++23)



 
 
定义于头文件 <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 起)

构造一个 tuple,它是 args 中所有 tuple 的串联。返回的 tuple 的元素类型 /* CTypes */ 通过按顺序串联 Tuples 中所有 std::tuple(C++23 前)tuple-like(C++23 起) 类型的元素类型包而形成。

如果 std::decay_t<Tuples>... 中的任何类型不是 std::tuple 的特化,则行为未定义。但是,实现可以选择支持遵循 tuple-like 协议的类型(例如 std::arraystd::pair)。

(C++23 前)

类型 std::decay_t<Tuples>... 被约束为 tuple-like,即,其中的每种类型都必须是 std::tuple 的特化,或另一种类型(例如 std::arraystd::pair),它们模拟 tuple-like

(C++23 起)

如果 /* CTypes */ 中的任何类型不能从由 args 串联的元素序列中的相应元素的类型构造,则行为未定义(C++23 前)则程序为非良构(C++23 起)

内容

[编辑] 参数

args - 零或更多要串联的 tuple

[编辑] 返回值

一个 std::tuple 对象,由从 std::get<j>(std::forward<Ti>(arg)) 构造的所有参数 tuple 的所有元素组成,用于每个单独的元素。

[编辑] 示例

#include <iostream>
#include <string>
#include <tuple>
 
// helper function to print a tuple of any size
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<typename... Args, std::enable_if_t<sizeof...(Args) == 0, int> = 0>
void print(const std::tuple<Args...>& t)
{
    std::cout << "()\n";
}
 
template<typename... Args, std::enable_if_t<sizeof...(Args) != 0, int> = 0>
void print(const std::tuple<Args...>& t)
{
    std::cout << "(";
    TuplePrinter<decltype(t), sizeof...(Args)>::print(t);
    std::cout << ")\n";
}
// end helper function
 
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)

[编辑] 参见

创建类型由实参类型定义的 tuple 对象
(函数模板) [编辑]
(C++11)
创建左值引用 tuple 或将 tuple 解包到各个对象中
(函数模板) [编辑]
创建转发引用 tuple
(函数模板) [编辑]