captures 捕获列表
,lambda可以把上下文变量以值或引用的方式捕获,在body中直接使用tparams 模板参数列表
(c++20引入),让lambda可以像模板函数一样被调用params 参数列表
,有一点需要注意,在c++14之后允许使用auto左右参数类型lambda-specifiers lambda
说明符, 一些可选的参数,这里不多介绍了,有兴趣的读者可以去官方文档上看。这里比较常用的参数就是mutable和exception。其中,表达式(1)中没有trailing-return-type,是因为包含在这一项里面的。trailing-return-type
返回值类型,一般可以省略掉,由编译器来推导body 函数体
,函数的具体逻辑[]
什么也不捕获,无法lambda函数体使用任何[=]
按值的方式捕获所有变量[&]
按引用的方式捕获所有变量[=, &a]
除了变量a之外,按值的方式捕获所有局部变量,变量a使用引用的方式来捕获。这里可以按引用捕获多个,例如 [=, &a, &b,&c]。这里注意,如果前面加了=,后面加的具体的参数必须以引用的方式来捕获,否则会报错[&, a]
除了变量a之外,按引用的方式捕获所有局部变量,变量a使用值的方式来捕获。这里后面的参数也可以多个,例如 [&, a, b, c]。这里注意,如果前面加了&,后面加的具体的参数必须以值的方式来捕获[a, &b]
以值的方式捕获a,引用的方式捕获b,也可以捕获多个[this]
在成员函数中,也可以直接捕获this指针,其实在成员函数中,[=]和[&]也会捕获this指针下面是一个简单的样例,在main函数内部定义了两个『函数对象』,一个是print 用来打印二维vector;另一个是cmp用来为sort函数提供排序标准,即根据第二个元素的大小从大到小排列。
#include
#include
#include
using namespace std;
int main()
{
auto print = [](vector> a) {
for(int i=0;i> A;
vector B({1,2}); A.push_back(B);
B=vector({2,1}); A.push_back(B);
B=vector({3,6}); A.push_back(B);
cout<<"----------Origin---------"< a, const vector b){return a[1]>b[1];};
sort(A.begin(), A.end(), cmp);
cout<<"----------After Sorted---------"<