将捕获范围变量的 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);
在我的 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);