C++ std::将右值参考转发给lambda?
考虑以下两个片段: 附件A:C++ std::将右值参考转发给lambda?,c++,lambda,c++11,forwarding,rvalue-reference,C++,Lambda,C++11,Forwarding,Rvalue Reference,考虑以下两个片段: 附件A: template<typename CalcFuncT> int perform_calc(CalcFuncT&& calcfunc) { precalc(); int const calc = calcfunc(); postcalc(); return calc; } int main() { perform_calc([]{ return 5 * foobar_x() + 3; }); //
template<typename CalcFuncT>
int perform_calc(CalcFuncT&& calcfunc)
{
precalc();
int const calc = calcfunc();
postcalc();
return calc;
}
int main()
{
perform_calc([]{ return 5 * foobar_x() + 3; }); // toFuture
perform_calc([]{ return 5 * foobar_y() - 9; }); // toPast
}
template<typename CalcFuncT>
int perform_calc(CalcFuncT&& calcfunc)
{
precalc();
int const calc = std::forward<CalcFuncT>(calcfunc)();
postcalc();
return calc;
}
int main()
{
perform_calc([]{ return 5 * foobar_x() + 3; }); // toFuture
perform_calc([]{ return 5 * foobar_y() - 9; }); // toPast
}
precalc();
- int const calc = calcfunc();
+ int const calc = std::forward<CalcFuncT>(calcfunc)();
postcalc();
模板
int perform_calc(CalcFuncT&calcfunc)
{
预LC();
int const calc=calcfunc();
后计算();
返回计算;
}
int main()
{
执行计算([]{return 5*foobar_x()+3;});//toFuture
执行计算([]{return 5*foobar_y()-9;});//toPast
}
附件B:
template<typename CalcFuncT>
int perform_calc(CalcFuncT&& calcfunc)
{
precalc();
int const calc = calcfunc();
postcalc();
return calc;
}
int main()
{
perform_calc([]{ return 5 * foobar_x() + 3; }); // toFuture
perform_calc([]{ return 5 * foobar_y() - 9; }); // toPast
}
template<typename CalcFuncT>
int perform_calc(CalcFuncT&& calcfunc)
{
precalc();
int const calc = std::forward<CalcFuncT>(calcfunc)();
postcalc();
return calc;
}
int main()
{
perform_calc([]{ return 5 * foobar_x() + 3; }); // toFuture
perform_calc([]{ return 5 * foobar_y() - 9; }); // toPast
}
precalc();
- int const calc = calcfunc();
+ int const calc = std::forward<CalcFuncT>(calcfunc)();
postcalc();
模板
int perform_calc(CalcFuncT&calcfunc)
{
预LC();
int const calc=std::forward(calcfunc)();
后计算();
返回计算;
}
int main()
{
执行计算([]{return 5*foobar_x()+3;});//toFuture
执行计算([]{return 5*foobar_y()-9;});//toPast
}
Diff:
template<typename CalcFuncT>
int perform_calc(CalcFuncT&& calcfunc)
{
precalc();
int const calc = calcfunc();
postcalc();
return calc;
}
int main()
{
perform_calc([]{ return 5 * foobar_x() + 3; }); // toFuture
perform_calc([]{ return 5 * foobar_y() - 9; }); // toPast
}
template<typename CalcFuncT>
int perform_calc(CalcFuncT&& calcfunc)
{
precalc();
int const calc = std::forward<CalcFuncT>(calcfunc)();
postcalc();
return calc;
}
int main()
{
perform_calc([]{ return 5 * foobar_x() + 3; }); // toFuture
perform_calc([]{ return 5 * foobar_y() - 9; }); // toPast
}
precalc();
- int const calc = calcfunc();
+ int const calc = std::forward<CalcFuncT>(calcfunc)();
postcalc();
precalc();
-int const calc=calcfunc();
+int const calc=std::forward(calcfunc)();
后计算();
这两段代码的生成代码之间有什么区别(如果有)
换句话说,std::forward在上述情况下有什么影响(如果有)
注意:这个问题不是问std::forward通常做什么-只是问它在上面的上下文中做什么?在调用操作符()之前,
forward
将lambda对象强制转换为xvalue。lambda对象的运算符()未使用“&&&”进行限定或重载,因此向前
应该没有影响。。我在那里使用std::forward
,因为调用者不一定总是lambda(它可能是带有重载操作符()的函子);如果调用方始终是lambda,那么使用std::forward
@ildjarn:如何重载只能作为成员函数的操作符()
s来区分右值this
与左值this
?这是C++11的新语法,在中引入,通俗称为“将移动语义扩展到*this”。本质上,&
和&
可以用作成员函数装饰器(除了通常的常量和volatile
)允许基于调用成员函数的对象的右值或左值进行重载。最好避免对函子的假设,例如用户将传递lambda。尽管右值限定的运算符()
会很奇怪(意味着一次函子),例B当然更正确,因为它允许这种情况。