浅谈C++11新引入的lambda表达式
|
ISO C++ 11 标准的一大亮点是引入Lambda表达式。基本语法如下:
简单的讲一下各个部分的作用 1.[capture list]捕获列表,捕获到函数体中,使得函数体可以访问 lambda表达式可以理解为一个匿名函数(但本质并不是),如果要使用lambda表达式声明的函数,需要给他“命名” lambda表达式可以表示闭包,因为本身就是这个类 闭包讲的通俗一些有以下几点 1.自带上下文的函数,闭包可以储存运行时需要的上下文,这样就可以在上下文不存在的时候还可以使用闭包(变量a生命周期到了被销毁,但是在闭包中还可以拿来用) 简单使用的例子 -------------------------------------------------------------------------------- C++11为auto提供了新的功能,如他的名字一般,现在可以看成自动适应类型,可以适应多数类型
auto f = [](){};
auto f = [](int a,int b)->int {return a + b; };
f(1,2);//需要这么使用
只要是函数类型就都可以使用这个lambda表达式
typedef int(*FUNC)(int a,int b);
int main()
{
FUNC a= [](int a,int b) {return a + b; };
printf("%dn",a(1,2));
}
声明函数的方法都可以接收不带捕获列表的lambda表达式
typedef std::function<int(int a,int b)> FUNC;
int main()
{
FUNC a= [](int a,2));
}
-------------------------------------------------------------------------------- lambda表达式中capture list的用法
int func(int a,int b,std::function<int(int,int)> f)
{
return f(a,b);
}
int a=1;
int b=2;
int c=3;
int d = func(a,b,[a,&b](int m,int n) {
printf("a = %dn",a); // a是通过值传递捕获,mutable只在函数体内修改有效
printf("b = %dn",b); // b是引用传递捕获,mutable可以对外部b造成影响
//printf("c = %dn",c); // c不可访问
return m + n;
});
typedef int(*FUNC)(int m,int n,int )> f);
void test()
{
FUNC oho;
int a = 10;
int b = 20;
auto func = [&a,int n) {printf("a:%d b:%dn",a,b); return m + n; };
}
1.[]空。没有使用任何函数对象参数。 当你想改变通过传值方式捕捉的变量的时候就要添加mutable
-------------------------------------------------------------------------------- lambda表达式的其他用法
class A
{
public:
A();
~A();
void test()
{
auto f = [this](int m,int n) {printf("%dn",a); };
}
private:
int a;
};
lambda表达式本质是一种闭包类型,虽然他可以赋值给函数指针,但是只限于在捕获列表为空的时候,当捕获列表有值的时候,应该使用auto来接收lambda表达式,或者用std::function也是可以的 main::__l2::<lambda_eb7b0a89c14bee3d2620c108ffb635c6> 本质来说lambda表达式之间是不允许赋值的
auto a = [](int m,int n) {return m + n; };
auto b = [](int m,int n) {return m - n; };
a = b;
操作非法,因为闭包类型不允许使用赋值操作符,但是函数指针可以,也就是可以有下面的操作
typedef int(*FUNC)(int a,int b);
int main()
{
FUNC a = [](int a,int b) {return a + b; };
FUNC b = [](int a,int b) {return a + b; };
a = b;
return 0;
}
std::function之间也是可以赋值的,他就可以办到有capture list的lambda表达式进行赋值
typedef std::function<int(int,int)> FUNC;
int m = 10;
int n = 20;
FUNC a = [m,n](int a,int b){printf("%dn",m); return a + b; };
FUNC b = [m,int b){return a + b; };
b = a;
b(1,2);
//执行结果是可以把m打印出来的
以上就是本文给大家介绍的c++11的新特性lambda表达式的全部内容了,希望大家能够喜欢 (编辑:温州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |


