[英]C++ How to use lambda expression to capture the previous iteration value?
我正在使用这个简单的例子来创建一个简单的向量,它的元素以严格递增的随机步进方式。 我有一个使用 function 对象的实现:
struct IncrementGenerator
{
int m;
IncrementGenerator() : m(0) {}
int operator()()
{
m += 1 + (rand() % 5); //random Increment between [1,5]
return m;
}
};
vector<int> myVector(10);
generate(myVector.begin()+1, myVector.end(), IncrementGenerator());
//example of the output: 0, 4, 6, 9, 10, 14, 15, 17, 20, 25,
我今天刚刚学习了 lambda 表达式,并希望用更短的代码来实现相同的实现。 我不确定是否可以在 lambda 表达式中捕获上一次迭代并在其上添加一个随机数:
// my idea is such, but not really sure what to write in the expression so i put some question mark.
generate(myVector.begin()+1, myVector.end(),[?]()->int{return ? + (1 + (rand()%5)) });
与上面的 class 等效的 lambda 是这样的:
auto increment_generator = [m = 0]() mutable
{
m += 1 + (rand() % 5); //random Increment between [1,5]
return m;
};
请注意mutable
修饰符,它指示捕获的m
不是恒定的。 默认情况下,lambda 捕获的变量是const
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.