我可以 std::forward 折叠表达式中的参数吗?

Ler*_*Cpp 5 c++ c++11 fold-expression c++17

在 C++11 中,我们有可变参数模板,我们可以在其中使用std::forward参数,如以下代码所示

#include <utility>
#include <iostream>
#include <string>

void printVariadic()
{}
template<typename T, typename... Args>
void printVariadic(T&& arg, Args&&... args)
{
   std::cout << arg << "\n";
   printVariadic(std::forward<Args>(args)...); // here we forward the arguments
}
Run Code Online (Sandbox Code Playgroud)

但是,在 C++17 中,我们有折叠表达式(根据我的理解,它直到最后一个参数才进行递归函数调用)。

template<typename ... Args>
void print(Args ... args)
{
    ((cout << args << "\n"), ...); // did we here miss the part of `std::forward`?
}
Run Code Online (Sandbox Code Playgroud)

std::forward在在线示例中,当使用折叠表达式时,我看不到参数的 ing。

我可以在折叠表达式中转发参数吗?或者我们根本不需要它?

这可能是一个愚蠢的初学者问题,但我仍然无法在网上找到答案。

max*_*x66 6

我可以在折叠表达式中转发参数吗?

是的

template<typename ... Args>
void print(Args && ... args)
{ // ...........^^
    ((cout << std::forward<Args>(args) << "\n"), ...);
}
Run Code Online (Sandbox Code Playgroud)

重点不是折叠。

关键是你如何接受争论。

如果您收到它作为价值

void print(Args ... args) // <-- by value
Run Code Online (Sandbox Code Playgroud)

您无法转发它(但您可以移动它)

如果你想转发它,你必须接收它作为转发参考,即带有模板类型和&&

template<typename ... Args>
void print(Args && ... args) // <-- forwarding reference
Run Code Online (Sandbox Code Playgroud)