我正在尝试关注this example以使用带remove_if
的lambda。这是我的尝试:
int flagId = _ChildToRemove->getId();
auto new_end = std::remove_if(m_FinalFlagsVec.begin(), m_FinalFlagsVec.end(),
[](Flag& device) {
return device.getId() == flagId;
});
m_FinalFlagsVec.erase(new_end, m_FinalFlagsVec.end());
但是无法编译:
error C3493: 'flagId' cannot be implicitly captured because no default capture mode has been specified
如何在lambda表达式中包含外部参数flagId
?
答案 0 :(得分:72)
您必须指定要捕获的flagId
。这就是[]
部分的用途。现在它没有捕获任何东西。您可以按值或按引用捕获(more info)。类似的东西:
auto new_end = std::remove_if(m_FinalFlagsVec.begin(), m_FinalFlagsVec.end(),
[&flagId](Flag& device)
{ return device.getId() == flagId; });
通过引用捕获。如果要按const值捕获,可以执行以下操作:
auto new_end = std::remove_if(m_FinalFlagsVec.begin(), m_FinalFlagsVec.end(),
[flagId](Flag& device)
{ return device.getId() == flagId; });
或者通过可变值:
auto new_end = std::remove_if(m_FinalFlagsVec.begin(), m_FinalFlagsVec.end(),
[flagId](Flag& device) mutable
{ return device.getId() == flagId; });
可悲的是,没有直接的方法来捕获const引用。我个人只会声明一个临时的const ref并通过ref:
捕获它const auto& tmp = flagId;
auto new_end = std::remove_if(m_FinalFlagsVec.begin(), m_FinalFlagsVec.end(),
[&tmp](Flag& device)
{ return device.getId() == tmp; }); //tmp is immutable
答案 1 :(得分:7)
它不会让我发表评论,因为我没有足够的“点”,但要回复 AndyG,现在有一种通过常量引用捕获的简单方法:
auto new_end = std::remove_if(m_FinalFlagsVec.begin(), m_FinalFlagsVec.end(),
[&flagId = as_const(flagId)](Flag& device)
{ return device.getId() == flagId; });