函数的内部的小函数定义(节省定义函数等事情),另外具备可以访问外部函数变量和this指针(选项控制)。
先看看lambda表达式变量截取的方式
- [] 不截取任何变量
- [&] 截取外部作用域中所有变量,并作为引用在函数体中使用
- [=] 截取外部作用域中所有变量,并拷贝一份在函数体中使用,作为只读
- [=, &foo] 截取外部作用域中所有变量,并拷贝一份在函数体中使用,但是对foo变量使用引用
- [bar] 截取bar变量并且拷贝一份在函数体重使用,只读,同时不截取其他变量
- [this] 截取当前类中的this指针。如果已经使用了&或者=就默认添加此选项。
在实际编写代码中可能会遇到如下情况:
这里使用伪代码:
void TestFun()
{
int a, b, c;
..... // 巴拉巴拉的一堆变量
if (条件1)
{
// 除了几个变量不同外都是相同的代码块
// 其中使用a、b、c....一堆变量
}
if (条件2)
{
// 除了几个变量不同外都是相同的代码块
// 其中使用a、b、c....一堆变量
}
if (条件3)
{
// 除了几个变量不同外都是相同的代码块
// 其中使用a、b、c....一堆变量
}
}
如果你在实际编写过程中遇到这类情况,(每个条件下都会调用相同或相似的代码块,并且代码块里面都大量使用了函数里的变量),未使用过Lambda第一时间可能会考虑函数调用,或者宏(宏这里就不说了),但是如果使用函数调用的话要考虑如下问题:
1、代码块中使用的一堆一堆的变量都用传参的方式来传递吗?
2、如果那一堆参数里面又加了几个参数,并且代码块都要用到,是要把函数传参接口改一下,在对每一个调用的地方改一下吗?
从上面两个问题中可以感觉,这时候普通的函数调用显得有些繁琐。那我们就要考虑lambda表达式了!
将上面的伪代码改写成如下:
void TestFun()
{
int a, b, c;
..... // 巴拉巴拉的一堆变量
// 代码块改成如下 使用&还是=或者既有&又有=根据自己实际情况决定
// param可以看做这个lambda中不同的变量
auto lambdaFun = [&](int param) -> void {
// 这里是可以直接调用到TestFun中的变量
// 使用a、b、c....一堆变量
}
if (条件1)
{
lambdaFun(param1);
}
if (条件2)
{
lambdaFun(param2);
}
if (条件3)
{
lambdaFun(param3);
}
}
通过lambda的调用,我们可以很方便的解决原本觉得繁琐的参数问题。