闭包的作用及优缺点

时间: 2019-08-28阅读: 902标签: 闭包

在面试题中,闭包应该是必问的问题吧(以下内容纯属个人理解,欢迎大家指正不足)下面我们就简单的了解一下闭包这个东西到底是什么


首先,我们先来讲讲什么是闭包?

简单来说就是一个定义在函数内部的函数,可以读取到其他函数内部变量的函数,本质上,闭包就是一个把函数内部和外部连接起来的桥梁

 

那我们读取函数内部的变量为什么要用到闭包呢,或者说闭包的作用是什么?

这就涉及到变量的生命周期问题了,函数内部定义的变量属于局部变量,局部变量的生命周期是:当它所在的函数被调用的时候,就是开始,当调用执行一旦结束,局部变量就会被释放,当我们需要函数内部变量时,他已经被释放了,读取不到了,这个时候怎么解决?我们就要想办法延长他的生命周期

闭包的目的也可以说就是这个,延长局部变量的生命周期,当函数执行完毕以后,局部变量不可以被内存释放,然后让外部可以访问到这个变量

 

那我们如何判断闭包是不是存在呢?闭包主要有以下几个特点:

1、函数套函数,闭包一定有嵌套函数

这个意思从闭包的字面定义上其实就可以大概推出来,定义在函数内部的函数;那为什么一定要函数套函数呢?因为需要局部变量,闭包的目的就是访问函数内部的局部变量,如果不定义局部变量,那就达不到我们的目的——延长变量生命周期

2、外层函数一定有局部变量,且内层函数一定操作了外层函数的这个变量

3、外层函数一定把内层函数返回外部,使用return

为什么要用return返回这个内层函数呢?因为如果不返回这个内层函数,你就没办法使用这个闭包,返回内层函数的最终的目的就是让外部可以访问到这个闭包,如果外部没办法访问闭包,那闭包怎么做函数内部和外部沟通的桥梁


在做闭包的问题时,我们还需要注意以下两点:

1、外层函数被多次调用,都会创建新的作用域,也就是说内层函数操作的外层函数的局部变量之间是不会影响的,这句话简单来说就是我第一次调用这个外层函数,使用了内部的局部变量 p;我第二次第三次再调用这个外层函数使用变量 p的时候,会创建新的作用域,并不会对之前的调用产生什么影响

2、外层函数返回的内层函数被调用几次,内层函数操作的外层函数的局部变量就会变化几次

上面两点都可以通过下面这段代码看出来


下面是具体的输出结果


对前面解释不明白的可以结合代码和输出结果来分析

第一点:每次的外层函数调用输出结果都是互不影响的,看每次调用的第一个输出结果都为0(这里调用的是外层函数);

第二点,在我【one第一次调用】【two第二次调用】【three第三次调用】的几次输出结果中可以看出,我每输出一次(内层函数被调用一次),变量的值就会发生变化,自增1,我输出几次也就是调用了几次,变量他就变化了几次

请注意上面虽然都是说调用,但是调用的函数是不同的,调用的是外层函数,变量互不影响,调用的是内层函数,那么变量变化会根据你调用的次数变化。这里我也不知道大家能不能明白我到底想表达个啥


 闭包的坏处

闭包使函数内部的变量不能被内存释放,这些变量就会占用内存,内存消耗大,可能会导致内存泄露

解决这个问题的办法就是在不使用这些变量时,及时把不需要的局部变量全部删除


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

链接: http://www.fly63.com/article/detial/5553

关闭

使用闭包的方式实现一个累加函数 addNum

使用闭包的方式实现一个累加函数 addNum,参数为 number 类型,每次返回的结果 = 上一次计算的值 + 传入的值

JS 原生闭包模块化开发总结

闭包模块的第一种写法;闭包模式的第二种写法;闭包模式的自动实例化对象的写法;闭包类的方法注入模式写法;

使用 JS 及 React Hook 时需要注意过时闭包的坑

闭包是一个函数,它从定义变量的地方(或其词法范围)捕获变量。闭包是每个 JS 开发人员都应该知道的一个重要概念。当闭包捕获过时的变量时,就会出现过时闭包的问题

JavaScript 闭包详解

闭包(closure)是Javascript语言的一个难点,也是它的特色,很多高级应用都要依靠闭包实现。闭包 是指有权访问另一个函数作用域中的变量的函数,创建闭包的最常见的方式就是在一个函数内创建另一个函数,通过另一个函数访问这个函数的局部变量

Js中的闭包

闭包是指有权访问另一个函数作用域中的变量的函数。创建闭包的常见方式就是在一个函数内部创建另一个函数。来看下面的示例:

JavaScript 作用域、命名空间及闭包

变量作用域:一个变量的作用域是程序源代码中定义这个变量的区域,在函数内声明的变量是局部变量,它只在该函数及其嵌套作用域里可见(js 函数可嵌套定义);

JavaScript中的匿名函数、立即执行函数和闭包

立即执行函数是基于匿名函数实现的,也没有函数名,会在定义后立即执行;闭包是有权访问另一个函数作用域中的变量的函数。匿名函数、立即执行函数只要满足 有权访问另一个函数作用域中的变量 这一个条件,就成了闭包。

深入了解JavaScript的闭包机制

这篇文章主要介绍了JavaScript的闭包机制,针对内嵌函数的变量访问等问题分析了JS的闭包,写的十分的全面细致,具有一定的参考价值,JavaScript 变量可以是局部变量或全局变量。 私有变量可以用到闭包。

JS闭包的应用(私有变量、珂理化、偏函数)

柯里化是把接受 n 个参数的 1 个函数改造为只接受 1个参数的 n 个互相嵌套的函数的过程。也就是fn(a, b, c)会变成fn(a)(b)(c)。偏函数和珂理化的区别是,不再强调单函数。例如1个入参返回2个入参函数。

Js函数高级-闭包

JavaScript的运行机制:(1)所有同步任务都在主线程上执行,形成一个执行栈。(2)主线程之外,还有一个“任务队列”,只要异步任务有了运行结果,就在“任务队列”之中放置一个事件。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!

文章投稿关于web前端网站点搜索站长推荐网站地图站长QQ:522607023

小程序专栏: 土味情话心理测试脑筋急转弯幽默笑话段子句子语录成语大全运营推广