函数对象(Lambdas)
C++11允许定义内部函数,可以当做参数或者对象使用。
格式和参数
[capture](parameters) mutable throwSpec ->retType {statement}
例如:
[](int a, int b) -> int { return a + b; }
[capture]:捕捉列表
捕捉列表总是出现的lambda表达式的开始处。事实上,[]是lambda引出符。编译器根据该引出符判断接下来的代码是否是lambda函数。捕捉列表能够捕捉上下文中的变量供lambda函数使用。
(parameters):参数列表
与普通函数的参数列表一致。如果不需要参数传递,则可以连同括号()一起省略。
mutable:mutable修饰符
默认情况下,lambda函数总是一个const函数,mutable可以取消其常量性。在使用该修饰符时,参数列表不可省略(即使参数为空)。
->return_type:返回类型
用追踪返回类型形式声明函数的返回类型。出于方便,不需要返回值的时候也可以连同符号->一起省略。此外,在返回类型明确的情况下,也可以省略该部分,让编译器对返回类型进行推导。
{statement}:函数体
内容与普通函数一样,不过除了可以使用参数之外,还可以使用所有捕获的变量。在lambda函数的定义式中,参数列表和返回类型都是可选部分,而捕捉列表和函数体都可能为空,C++中最简单的lambda函数只需要声明为:[]{};
值传递
和引用传递
不同
[]:没有定义任何变量,使用未定义的变量会引发错误
[x, &y]:x以值传递方式传入(默认),y以引用的方式传入
[&]:任何被使用到的外部变量都被隐式地以引用方式加以引用
[=]:任何被使用到的外部变量都被隐式地以传值方式加以引用
[&, x]:x显式地以传值方式加以引用,其余变量以引用方式加以引用
[=, &z]:z显式的以引用方式加以引用,其余变量以传值方式加以引用
使用this指针
对于[=]或[&]的形式,lambda表达式可以直接使用this指针,但是对于[]的形式,如果要使用this指着,必须显式传入:
[this]() { this->someFunc(); }();
用法
auto f = [](int a, int b) { return a + b; }; // ok 自动推断出返回类型
int f = [](int a, int b) { return a + b; }; // error
int f = [](int a, int b) ->int { return a + b; }; // error
参考
https://www.jianshu.com/p/d4c0702d99d0