lambda表达式底层原理

lambda表达式底层原理,第1张

转载:C++拾遗--lambda表达式原理_苏叔叔的博客-CSDN博客_c++ lambda表达式原理

以前没有细细研究lambda表达式的底层原理,不清楚很多面试官问道C++11就喜欢问这个,居然喜欢问,那就研究一下原理。平常都是直接使用,但是具体原理确实不懂。仔细看,底层原理使用到了函数对象方法。

重点:

1.包括四种:无参数、有参数、值捕获、引用捕获

2.mutable:关键字可以去除const的限制。

1.没带任何参数的lambda表达式:

auto a=[](){...};

2.带参数的lambda表达式:

auto a=[](int a){...};

 3.引用捕获

注意:引用时候的妙用,注意私有变量和构造函数

 

4.值捕获和引用捕获

默认情况下,经过值捕获的变量是不可以被修改的,除非在参数列表后加关键字mutable。以上代码展示了,对应类中mutable是如何加的。当然还有另一种实现方法,只要lambda表达式加了mutable,重载函数调用运算符时就不加const修饰。

 

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1325544.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-12
下一篇 2022-06-12

发表评论

登录后才能评论

评论列表(0条)

保存