lambda表达式
1. 什么是lambda表达式?
lambda表达式表示可调用的代码单元,类似于内联函数。一般形式如下:
[capture list](parameter list) -> return type{ function body}
capture list(捕获列表),函数中的局部变量,可以为空,多个时用逗号隔开,
静态局部变量和函数外声明的变量(类似全局变量)使用时不必放到捕获列表 ,
可以直接调用
parameter list 形参列表
return type 返回类型
2. 为什么使用lambda表达式?
有些函数在调用时函数时只接受一元谓词,即传递的任何函数都只接受一个参数,
如algorithm中的find_if()函数,find_if(s.begin(), s.end(), ‘a’);
为了处理这种情况,我们就可以使用lambda表达式来实现传递多个参数;
3. lambda表达式的使用方法?
- 可以删除参数列表和范围类型,但捕获列表和函数体一定要有:
auto num = []{return 15}; // num() = 15
cout << num() << endl; //注意,num是一个函数,使用要加上();
- 向lambda传递参数:
[](string& a, stirng& b){ //传入参数
return a.size() > b.size();
};
//列如
auto f = [](string a, string b) {
return a.size() > b.size();
};
cout << f("abc", "bcd") << endl; //输出0(false)
- 使用捕获列表,只需局部变量,静态局部变量和函数外的变量不用捕获就可使用:
int main(){
int len = 5;
auto f = [len](string& str){
return str.size() < len;
};
}
捕获的对象也可以是引用,但必须确保当前函数中捕获的引用指向的局部变量存在,
因为有的lambda可能在函数结束后执行,此时局部变量就消失了。
string s = "123456";
int len = 5;
auto fun = [len](string& str){
return str.size() > len;
};
auto fun2 = [&len](string& str){
return str.size() > len;
};
len = 10;
cout << fun(s) << endl; //1
cout << fun2(s) << endl; //0
- 隐式捕获
- 在捕获列表中只写入一个&或=。&代表采用引用的捕获方式,=代表值捕获方式,此时就可以直接使用局部变量。
- 显示与隐式混合使用时:
如果隐式使用&来捕获,则显示就要使用值捕获方式; 如果隐式使用=来捕获,则显示需要使用&来捕获; 总之二者不能使用通一种方式捕获。
- 结合algorithm中的排序sort函数使用例子:
int main(){
vector<int> nums{ 1,5,3,9,2,7 };
sort(nums.begin(), nums.end(), [](int a, int b){
return a > b; //非递增
};
}
- 指定lambda返回类型
默认情况下,如果一个lambda体包含return之外的任何语句,则编译器会假定此lambda返回void,此时就需要指定一个返回类型。
例如
auto f = [](int num){
if(num < 0){
return -num;
}
else{
return num;
}
}
改为
auto f = [](int num) ->int {
if(num < 0){
return -num;
}
else{
return num;
}
}