存储lambda函数,该函数将范围变量捕获为类成员以供重用



在我的类中,许多方法都有这样的代码片段:

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);

最新更新