Descrição
Ele constrói um objeto de tupla com referências rvalue aos elementos em args adequados para serem encaminhados como argumento para uma função.
Declaração
A seguir está a declaração para std :: forward_as_tuple.
C ++ 98
template<class... Types>
tuple<Types&&...> forward_as_tuple (Types&&... args) noexcept;
C ++ 11
template<class... Types>
tuple<Types&&...> forward_as_tuple (Types&&... args) noexcept;
C ++ 14
template<class... Types>
constexpr tuple<Types&&...> forward_as_tuple (Types&&... args) noexcept;
Parâmetros
args - Contém lista de elementos que a tupla construída deve conter.
Valor de retorno
Ele retorna um objeto de tupla do tipo apropriado para conter args.
Exceções
No-throw guarantee - esta função de membro nunca lança exceções.
Corridas de dados
Nenhum introduzido por esta chamada.
Exemplo
No exemplo abaixo para std :: forward_as_tuple.
#include <iostream>
#include <tuple>
#include <string>
void print_pack (std::tuple<std::string&&,int&&> pack) {
std::cout << std::get<0>(pack) << ", " << std::get<1>(pack) << '\n';
}
int main() {
std::string str ("Tutorialspoint.com");
print_pack (std::forward_as_tuple(str+" sairamkrishna",25));
print_pack (std::forward_as_tuple(str+" Gopal",22));
print_pack (std::forward_as_tuple(str+" Ram",30));
return 0;
}
A saída deve ser assim -
Tutorialspoint.com sairamkrishna, 25
Tutorialspoint.com Gopal, 22
Tutorialspoint.com Ram, 30