简单如我,但是更好的图帖子在这里:
超链接:
这个帖子讲的太好了,还有函数对象
看一个求余函数的例子:
auto mod = [](int i,int j){return i%j;};
一、lambda表达式
[capture list] (parameter list) -> return type { function body}
1 capture list
是一个lambda所在函数中定义的局部变量的列表,通常为空;
2 return type
返回值类型;
可忽略,使用自动推倒;
尾置返回类型;就是用 ->后面跟类型 来表示函数的返回类型,这样更直观;
3 parameter list
参数列表;
可忽略,自动推倒;
4 function body
函数体;
二、最简单的lambda表达式:
auto f = [] { return 42; }
不接受参数; 返回42;
三、与STL结合的lambda表达式:
stable_sort( words.begin(), words.end(),
[] ( const string& a, const string& b) { return a.size() < b.size(); }
);
当作函数对象
四、使用捕获列表:
值捕获
[sz] (const string& a) { return a.size() >= sz;}
引用捕获
[&sz] (const string& a) { return a.size() >= sz;}
五、隐式捕获
捕获所有lambda表达式外的局部变量
值捕获所有
[=] (const string& a) { return a.size() >= sz;}
引用捕获所有
[&] (const string& a) { return a.size() >= sz;}