调用完美转发的 lambda

问题描述

我有以下类,它存储对函数的完美转发引用:

template <class F> 
class Visitor
{
public:
    Visitor(F &&f) : _f(std::forward<F>(f)) 
    {
    }

    xt::LOOP_CONTROL OnElem(xvi::Elem &elem)
    {
        return _f(elem);

        // or should it be: 
        // return std::forward<F>(_f)(elem);
    }

private:
    F &&_f;
};

想知道调用 _f(elem)std::forward<F>(_f)(elem); 是否有区别?

解决方法

Lambda 目前不能有 ref 限定 operator (),所以对它们来说,两种形式是等价的。

对于自定义函子,它可能与 std::forward<F>(_f)(elem); 不同:

struct MyFunctor
{
    xt::LOOP_CONTROL operator()(xvi::Elem &elem) &  { std::cout << "lvalue"; return {};}
    xt::LOOP_CONTROL operator()(xvi::Elem &elem) && { std::cout << "rvalue"; return {};}
};

xvi::Elem elem;
Visitor<MyFunctor>(MyFunctor{}).OnElem(elem); // rvalue
MyFunctor func;
Visitor<MyFunctor&>(func).OnElem(elem); // lvalue