闭包
闭包就是函数内的函数,其实就是oc里的block。
lambda表达式可以访问当前作用域的变量,c++变量传递有传值和传引用的区别,可以通过[]来指定:
基本规则:
基本形式:[捕获列表](参数列表){函数体};其中捕获列表和函数体不可以省略但是捕获列表可以为空,所以简单的表达式:[]{};
它的返回值类型不需要显示写出来。而是由函数体力的return语句决定。因此一般使用auto关键字自动推导。
捕获列表的参数必须是前面已经定义了的。
使用mutabel关键字来修改传值的捕获参数,但是改变后的参数不会在lambda表达式外生效。
捕获列表和参数列表的区别在于:一个是定义时传递的参数,一个是调用时传递的参数。
空的lambda表达式:auto fun = [](){};
捕获列表只用于捕获局部非static变量;
[]
[x,&y]
[&]
[=]
[&,x]
[=,&z]
值捕获:
1:被捕获的变量是可以被拷贝的;
2:捕获列表的参数的捕获时机是在定义的时候,而不是调用时。
int data(2);
auto func = [data]()mutable{
data = 3;
globle_data = 4;
cout<<"lambda函数体里面:"<<"globle_data="<<globle_data<<"; data="<<data<<endl;
};
cout<<"lambda调用之前:"<<"globle_data="<<globle_data<<";data="<<data<<endl;
func();
cout<<"lambda调用之后:"<<"globle_data="<<globle_data<<";data="<<data<<endl;
引用捕获:变量前加&:
int data2(2);
auto func2 = [&data2]()mutable{
data2++;
cout<<"lambda函数体里面:"<<"data2="<<data2<<endl;
};
cout<<"lambda调用之前:"<<"data2="<<data2<<endl;
func2();
cout<<"lambda调用之后:"<<"data2="<<data2<<endl;
隐式捕获:
int a,b,c
a=b=c=0
auto func3 = [=]()mutable{//注意这个mutable
a++
b++
c++
cout<<"fun3 lambda里面"<<"a="<<a<<";"<<"b="<<b<<":"<<"c="<<c<<endl
}
auto func4 = [&](){
a++
b++
c++
cout<<"fun4 lambda里面"<<"a="<<a<<";"<<"b="<<b<<":"<<"c="<<c<<endl
}
auto func5 = [=,&a]()mutable{
a++
b++
c++
cout<<"fun5 lambda里面"<<"a="<<a<<";"<<"b="<<b<<":"<<"c="<<c<<endl
}
auto func6 = [&,a]()mutable{
a++
b++
c++
cout<<"fun5 lambda里面"<<"a="<<a<<";"<<"b="<<b<<":"<<"c="<<c<<endl
}
func3()
cout<<"fun3 lambda之后"<<"a="<<a<<";"<<"b="<<b<<":"<<"c="<<c<<endl
a=b=c=0
func4()
cout<<"fun4 lambda之后"<<"a="<<a<<";"<<"b="<<b<<":"<<"c="<<c<<endl
a=b=c=0
func5()
cout<<"fun5 lambda之后"<<"a="<<a<<";"<<"b="<<b<<":"<<"c="<<c<<endl
a=b=c=0
func6()
cout<<"fun6 lambda之后"<<"a="<<a<<";"<<"b="<<b<<":"<<"c="<<c<<endl