关闭

闭包的作用及优缺点

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

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


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

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

 

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

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

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

 

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

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

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

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

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

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


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

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

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

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


下面是具体的输出结果


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

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

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

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


 闭包的坏处

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

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


站长推荐

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

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

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

关闭

如何才能通俗易懂的解释js里面的‘闭包’?

即变量都存在在指定的作用域中,如果在当前作用中找不到想要的变量,则通过作用域链向在父作用域中继续查找,直到找到第一个同名的变量为止(或找不到,抛出 ReferenceError 错误)。这是 js 中作用域链的概念

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

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

JavaScript之闭包

闭包(closure)是掌握Javascript从人门到深入一个非常重要的门槛,它是Javascript语言的一个难点,也是它的特色,很多高级应用都要依靠闭包实现。下面写下我的学习笔记~

带你一分钟理解 JavaScript 闭包

闭包就是一个函数引用另外一个函数的变量,因为变量被引用着所以不会被回收,因此可以用来封装一个私有变量。这是优点也是缺点,不必要的闭包只会徒增内存消耗!另外使用闭包也要注意变量的值是否符合你的要求

Js中闭包的概念、原理、作用及应用

闭包:有权访问另一个函数作用域中的变量的函数,一般情况就是在一个函数中包含另一个函数。从官方定义我们知道闭包是一个函数,只不过这个函数有[超能力],可以访问到另一个函数的作用域。为什么说这个叫做[超能力]呢?

理解js闭包9大使用场景

函数赋值在闭包里面给fn2函数设置值,闭包的形式把name属性记忆下来,执行会输出 hello。getter和setter第一次输出 hello 用setter以后再输出 world ,这样做可以封装成公共方法

深入理解Js闭包

《JavaScript权威指南》:函数对象可以通过作用域链相互关联起来,函数体内部的变量可以保存在函数作用域内,这种特性称为“闭包”。不好理解?那就通俗点讲:所谓闭包,就是一个函数,这个函数能够访问其他函数的作用域中的变量。

JavaScript闭包应用介绍

闭包是JS中的强大特性之一,然而至于闭包怎么使用,我觉得不算是一个问题,甚至我们完全没必要研究闭包怎么使用。我的观点是,闭包应该是自然而言地出现在你的代码里,因为它是解决当前问题最直截了当的办法

javascript中闭包最简单的介绍

JavaScript 变量可以是局部变量或全局变量。私有变量可以用到闭包。闭包就是将函数内部和函数外部连接起来的一座桥梁。函数的闭包使用场景:比如我们想要一个函数来执行计数功能。

Js中的闭包与高级函数

在JavaScript中,函数是一等公民。JavaScript是一门面向对象的编程语言,但是同时也有很多函数式编程的特性,如Lambda表达式,闭包,高阶函数等,函数式编程时一种编程范式。

点击更多...

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