forward完美转发主要是用来保持转发的语义和之前的一致,常常会在出现move移动语义的代码中出现,看个例子:
#include <utility>
#include <iostream>
void bar(const int& x)
{
std::cout << "lvalue" << std::endl;
}
void bar(int&& x)
{
std::cout << "rvalue" << std::endl;
}
template <typename T>
void foo(T&& x)
{
bar(x);
}
int main()
{
int x = 1;
foo(x);
foo(1);
return 0;
}
打印结果中foo(1)会输出lvalue,这可能不是预想的结果,因为1明明是右值rvalue。正确的做法可以使用forward来实现,把bar(x)改为:bar(std::forward<T>(x)),这样一来就能输出rvalue了。
参考资料: