C++2.0新特性之lambdas(一)
作者:互联网
什么是lambdas?
在2.0中加入lambdas表达式,它允许我们定义出 ‘被用来当成一个参数或者是局部对象的内联函数’。lambdas改变了对标准库的使用。
lambdas最简单的使用方法:
[] {
std::cout<<“hello lambdas”<<std::endl;
}
我们可以通过后面加 ‘()’ 的方式直接调用它:
[] {
std::cout<<“hello lambdas”<<std::endl;
}(); //prints “hello lambdas”
这样做难免会有点多此一举,所以大多数情况下我们会像下面这样写:
上面的书写形式就像是inline一样,我们还可以将lambdas写入一个或多个声明中或是表达式中去。
lambdas的完整形式是这样的:
[…] (…) mutable throwSpec -> retType {…}
下面介绍一下此表达式的各个段的意义:
1,第一段 [ …] 是lambdas表达式的标志性符号,看见 此符号就应该知道,这是lambdas表达式。‘[…]’内可以使用外部变量
2,第二段(…) 里可以放入参数。
3,mutable关系着 […] 里的数据是否可以被改写。
4,throwSpec表示抛出异常。
5,retType 是描述 […] 的返回类型。
6,{…}是函数本体
注意:3,4,5是可选操作,可以都不写,如果都不写的话,(…)可写可不写(前提是没有参数),但是只要三者存在一个,就必须有(…);
如果想要在函数体内部改变外部变量id的值,就必须加上mutable操作,否则id的值无法改变,编译器会报错。
上述操作也可以看成是仿函数 (形式相同,但不是完全相同):
我们明明已经把id变为22了,为什么输出结果还是0,1呢?
因为传参是值传递,在编译时编译器发现id初始值为0,所以编译器进行了优化,将变量优化成了常变量0,所以后面函数体内的id都是从0开始加起,与外部id的值无关。
当参数是引用时mutable操作可写可不写
当我们将参数变为引用传递时就会发现,外部id变化的同时lambdas内部id的值也会变化,这就是引用传参。
标签:函数,C++,编译器,mutable,2.0,id,表达式,lambdas 来源: https://blog.csdn.net/qq_48168706/article/details/122676893