将捕获范围变量的 lambda 函数存储为 class 成员以重用

Store lambda function that captures the scope variable as a class member to reuse

在我的 class 很多方法中都有这样的片段:

std::string str = getSomeStr();

auto it = std::find_if(
vec.begin(), 
vec.end(), 
[str](const std::string& b){return str + "abc" == b;});

因此,我想存储 lambda 函数以重用它。但是它从范围中捕获了 str 。我应该怎么做?

如果我没理解错的话...

class MyOperation {
    std::string s;
public:
    MyOperation(std::string s) : s(s) { }

    operator()(const std::string& b) {
        return s + "abc" == b;
    }
};

用法:

std::string str = getSomeStr();

auto it = std::find_if(
    vec.begin(), 
    vec.end(), 
    MyOperation(str));

您不必使用 str 临时文件,或使 MyOperation 仅包含 std::string 引用。这取决于你想达到什么目的。


当然技术上你可以这样做:

auto myOperation(std::string s) { 
    return [s = std::move(s)](const std::string& b) {
        return s + "abc" == b;
    };
}

但坦率地说,我不明白这一点。

如何通过引用捕获然后在每次使用前分配给该引用:

std::string str = getSomeStr();
std::string str2 = getSomeOtherStr();
std::string *captured_str;

auto lambda =  [&captured_str](const std::string* b){return *str + "abc" == b;}

captured_str = &str;
auto it = std::find_if(vec.begin(), vec.end(), lambda);
captured_str = &str2;
auto it = std::find_if(vec.begin(), vec.end(), lambda);