
Halo,这里是Ppeua。平时主要更新C++,数据结构算法,Linux与ROS…感兴趣就关注我bua!
在C++98及之前,想要对sort进行自定义排序,或者对自定义类型进行排序需要写一个仿函数。
例如,想要从大到小对num进行排序需要这样写
struct Greater{
bool operator()(int x,int y)
{
return x>y;
}
};
int main()
{
vector<int>num;
sort(num.begin(),num.end(),Greater());
}
为了一个可能只在全局中使用一次的函数来创建一个类得不偿失,也有点麻烦.所以引入了Lambda表达式
在C++11,引入了Lambda表达式来解决这个问题,其更像一种匿名函数.生命周期只在当前这一行
继续引用上文排序的例子,现在可以这样写
int main()
{
vector<int>num;
sort(num.begin(),num.end(),[](int x,int y){
return x>y;
});
}
仅需要一行即可完成该功能,该函数生命周期也仅在这一行.
这个表达式长得十分Python,是从Python那引用过来的特性
Lamda表达式总体框架
[capture-list](parameters)mutable ->return-type {
{statement}
}
statement:为函数体,正常写函数即可
parameters:为参数列表
mutable:可取消参数列表的常量属性
return-type:return-type可由编译器自动推导可省略
capture-list:参数捕获列表,可以理解为接下来可以在函数中使用哪些已有的变量
这些可以进行一个组合,表示复制所有全局变量,仅引用a与b,不可重复引用
[=,&a,&b](){
}
重复引用
[=,a,b](){
}
一个引用了全局变量的例子
int a=0,b=1;
auto f1=[&,a]()mutable{
a++,b++;
};
f1();
cout<<a<<" "<<b;
这里的结果为0,1.加上mutable是为了解决a为const的限制,即可对a进行自增的操作.
Lambda表达式之间不可以互相赋值,即使看起来类型相同,但其背后的类型是不同的.我们用typeid来查看下
auto f2=[](){cout<<"hello";return 0;};
auto f1=[](){cout<<"hi";return 0;};
cout<<"f2: "<<typeid(f2).name()<<endl;
cout<<"f1: "<<typeid(f1).name();

很明显其为不同的函数类型,所以不可以互相赋值
其底层为函数对象(仿函数)实现的,本质上没有什么差别

