JS中lambda表达式

JavaScript025

JS中lambda表达式,第1张

了解过js函数的同学应该都知道js的函数有很多种创建方式。 如: function fun(){}; var fun=function(){}; 但最近的学习中发现了lambda表达式型的创建js的匿名函数 ()=>{} 小括号内放置参数,大括号内为函数内容; eg: (()=>{console.log('lambda')})() 实现了匿名函数的自调;

闭包是指有权访问另外一个函数作用域中的变量的函数。

闭包就是函数的局部变量集合,只是这些局部变量在函数返回后会继续存在。闭包就是就是函数的“堆栈”在函数返回后并不释放,我们也可以理解为这些函数堆栈并不在栈上分配而是在堆上分配。当在一个函数内定义另外一个函数就会产生闭包。

作用是:匿名自执行函数:我们知道所有的变量,如果不加上var关键字,则默认的会添加到全局对象的属性上去,这样的临时变量加入全局对象有很多坏处,如:别的函数可能误用这些变量;造成全局对象过于庞大,影响访问速度(因为变量的取值是需要从原型链上遍历的)。除了每次使用变量都是用var关键字外,我们在实际情况下经常遇到这样一种情况,即有的函数只需要执行一次,其内部变量无需维护,可以用闭包。

结果缓存:我们开发中会碰到很多情况,设想我们有一个处理过程很耗时的函数对象,每次调用都会花费很长时间,那么我们就需要将计算出来的值存储起来,当调用这个函数的时候,首先在缓存中查找,如果找不到,则进行计算,然后更新缓存并返回值,如果找到了,直接返回查找到的值即可。闭包正是可以做到这一点,因为它不会释放外部的引用,从而函数内部的值可以得以保留。

在 c++ 中 lambda 函数有点类似匿名函数,怎么解释呢,我们无需定义一个函数结构随后再去使用这个函数。而是直接在使用时将其声明使用。

再进一步解释可以将函数赋值给变量,然后通过变量再去调用函数。我们学习一个新特性不是如何使用这个语法,而是在什么场景下恰当地去使用这个语法来解决实际问题。不要为了特效而改变故事情节,一个好的程序在其情节而不是特效。所以不要为了用而用。

lambda 是字面上定义一个函数而不是持有一个函数。也就是我们可以使用函数指针的场景是可以使用 lambda 来代替的。参照 c++ 基础(函数指针)

定义 void ForEach(const std::vector<int>&values, void (*func)(int)) 接收两个参数一个 vector<int>动态数组,一个是指针函数作为参数。在调用函数 ForEach 时候第二个参数我们传入一个 [](int value) { std::cout <<"value: " <<value <<std::endl} 一个 lambda 作为第二参数传入到函数 ForEach 中。 void (*func)(int) 定义传入 lambda 的格式是返回值为 void 接收一个 int 类型的参数。

在循环体中的 func(value) 会调用 lambda 函数。

大家感觉陌生和疑惑可能是 [] ,今天对这个解释一下,看了一些有关 [] 解释的参考资料,感觉和之前学习的 angularjs 中有关 directive 变量定义内部是对外的引用、还是复制的=,&符号含义有点相似,这些符号主要传入到 directive 的变量是传值还是传引用。可能是 angularjs 设计者参考c++的做法了吧。

在 c++ 中 [] 为 lambda 的捕获区,用于捕获外部变量,我们可以看一看。

这里我们需要修改第二个参数传入的类型 const std::function<void(int)>&func 。

如果想要在 lambda 表达式中修改传入的变量 a ,就需要使用 lambda 表达式中添加 一个 mutable 的说明符。

下面看一个 lambda 的具体应用,在 algorithm 库中提供了find_if 函数最后一个参数接收函数作为参数,我们可以传入一个 lambda 表达式来作为参数。