std::tuple_cat
Определено в заголовочном файле <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 */ возвращаемого кортежа формируются путём объединения пакетов типов элементов всех std::tuple (до C++23)tuple-like
(начиная с C++23) типов в Tuples
по порядку.
Поведение не определено, если какой-либо тип в std::decay_t<Tuples>... не является специализацией std::tuple. Однако реализация может выбрать поддержку типов (таких как std::array и std::pair), которые следуют кортежеподобному протоколу. |
(до C++23) |
Типы std::decay_t<Tuples>... ограничены кортежем, т.е. каждый тип в них должен быть специализацией std::tuple или другого типа (например, std::array и std::pair), которые моделируют |
(начиная с C++23) |
Если какой-либо тип в /* CTypes */ не может быть создан из типа соответствующего элемента в последовательности элементов, объединённых из args, поведение не определено (до C++23)программа некорректна (начиная с C++23).
Содержание |
[править] Параметры
args | — | ноль или более кортежей для конкатенации |
[править] Возвращаемое значение
Объект std::tuple, состоящий из всех элементов всех кортежей аргументов, созданных из std::get<j>(std::forward<Ti>(arg)) для каждого отдельного элемента.
[править] Пример
#include <iostream> #include <string> #include <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 <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"; } // конец вспомогательной функции int main() { std::tuple<int, std::string, float> t1(10, "Тест", 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, Тест, 3.14, Foo, bar, 10, Тест, 3.14, 42)
[править] Смотрите также
(C++11) |
создаёт объект tuple типа, определённого типами аргументов (шаблон функции) |
создаёт tuple левосторонних ссылок или распаковывает кортеж на отдельные объекты (шаблон функции) | |
(C++11) |
создаёт tuple пересылалаемых ссылок (шаблон функции) |