一个lambda表达式表示一个可调用的代码单元。可以将其理解为一个未命名的内联函数。与普通函数类似,一个lambda具有一个返回类型、一个参数列表和一个函数体。与普通函数不同的是,lambda可以定义在其他函数内部。一个lambda表达式具有如下形式:
[capture list](parameter list)-> return type { function body }
其中,capture list(捕获列表)是一个lamda所在函数中定义的局部变量的列表(通常为空);return type、parameter list和function body与任何普通函数一样,分别表示返回类型、参数列表和函数体。但与普通函数不同的是,lambda必须使用尾置返回来指定返回类型。
注:如果lambda的函数体包含任何单一return语句之外的内容,且未指定返回类型,则返回void。
以下是一个使用lambda函数的函数示例,该函数接受两个参数(一个vector<string>类型的容器和一个vector<string>类型的尺寸参数),函数计算输入容器内大于给定尺寸的数据的个数并打印这些数据:
viod biggies(vector<string> &words, vector<string>::size_type sz)
{
elimDups(words); //自定义函数,将words按字典顺序排序,删除重复单词
// 按长度排序,长度相同的单词维持字典序
stable_sort(words.begin(),words.end(),
[](const string &a, const string &b){ return a.size()<b.size(); });
// 获取一个迭代器,指向第一个满足size()>=sz的元素
auto wc=find_if(words.begin(),words.end(),
[sz](const string &a){ return a.size()>=sz; });
// 计算满足size>=sz的元素的数目
auto count=words.end()-wc;
cout<<count<<" "<<make_plural(count,"word","s")
<<" of length "<<sz<<" or longer "<<endl;
// 打印长度大于等于给定值的单词,每个单词后面接一个空格
for_each(wc,words.end(),[](const string &s){ cout<<s<<" ";});
cout<<endl;
}
注:一个lambda只有在其捕获列表中捕获一个它所在函数中的局部变量,才能在函数体中使用该变量。捕获列表只适用于局部非static变量,lambda可以直接使用局部stati变量和它所在函数之外声明的名字。
建议:尽量保持lambda的变量捕获简单化
lambda捕获列表