Пространства имён
Варианты
Действия

std::forward_as_tuple

Материал из cppreference.com
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(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)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
 
<tbody> </tbody>
Определено в заголовочном файле <tuple>
template< class... Types > tuple<Types&&...> forward_as_tuple( Types&&... args ) noexcept;
(начиная с C++11)
(constexpr since C++14)

Создаёт кортеж ссылок на аргументы в args, подходящий для передачи в качестве аргумента функции. Кортеж имеет ссылочные элементы данных rvalue, когда rvalue используются в качестве аргументов, и в противном случае имеет ссылочные элементы данных lvalue.

Параметры

args ноль или более аргументов для построения кортежа

Возвращаемое значение

Объект std::tuple, созданный как бы с помощью std::tuple<Types&&...>(std::forward<Types>(args)...)

Примечание

Если аргументы являются временными, forward_as_tuple не продлевает их время жизни; они должны использоваться до конца полного выражения.

Пример

#include <iostream>
#include <map>
#include <tuple>
#include <string>

int main()
{
    std::map<int, std::string> m;

    m.emplace(std::piecewise_construct,
              std::forward_as_tuple(10),
              std::forward_as_tuple(20, 'a'));
    std::cout << "m[10] = " << m[10] << '\n';

    // Следующее это ошибка: создаётся
    // std::tuple<int&&, char&&> содержащий две висячие ссылки.
    //
    // auto t = std::forward_as_tuple(20, 'a');
    // m.emplace(std::piecewise_construct, std::forward_as_tuple(10), t);
}

Вывод:

m[10] = aaaaaaaaaaaaaaaaaaaa

Смотрите также

создаёт объект tuple типа, определённого типами аргументов
(шаблон функции) [править]
создаёт std::tuple левосторонних ссылок или распаковывает кортеж на отдельные объекты
(шаблон функции) [править]
(C++11)
создаёт tuple, объединяя любое количество кортежей
(шаблон функции) [править]
(C++17)
вызывает функцию с кортежем аргументов
(шаблон функции) [править]