首页 > Web开发 > 详细

JS 闭包的理解

时间:2019-02-27 17:11:47      阅读:132      评论:0      收藏:0      [点我收藏+]

先写一个简单闭包函数

function A(){
    function B(){
       console.log(Hello Closure!);
    }
    return B;
}
var C = A();
C();// Hello Closure!

这个闭包函数的执行过程为

1、定义普通函数 A

2、在 A 函数内部定义 普通函数 B

3、在 A 函数中返回 B

4、执行 A ,并把 A 返回的结果赋值给变量 C

5、执行 C

总结起来就是:

函数A的内部函数B被函数A外的一个变量 c 引用。

那么闭包的定义就就是:

当一个内部函数被其外部函数之外的变量引用时,就形成了一个闭包。

 

注意!闭包和内存泄漏和内存回收之间的关系

内存回收:avaScript是一种具有垃圾回收机制的语言——对象在创建时分配内存,当一个对象不再被引用的时候,这个对象就会被浏览器回收,

否则这个对象就会一直保存在内存中。

 内存泄漏是指我们已经无法再通过js代码来引用到某个对象,但垃圾回收器却认为这个对象还在被引用,因此在回收的时候不会释放它。

致了分配的这块内存永远也无法被释放出来。如果这样的情况越来越多,会导致内存不够用而系统崩溃。

在上述例子中,B 定义在 A 中,因此 B 依赖于 A ,而外部变量 C 又引用了 B , 所以A间接的被 C 引用。

 

也就是说,A 不会被 GC 回收,会一直保存在内存中。

上述例子进行改进

function A() {
    var count = 0;
    function B() {
       count ++;
       console.log(count);
    }
    return B;
}
var C = A();
C();// 1
C();// 2
C();// 3

count 是函数A 中的一个变量,它的值在函数B 中被改变,函数 B 每执行一次,count 的值就在原来的基础上累加 1 。因此,函数A中的 count 变量会一直保存在内存中。

当我们需要在模块中定义一些变量,并希望这些变量一直保存在内存中但又不会 “污染” 全局的变量时,就可以用闭包来定义这个模块

 

JS 闭包的理解

原文:https://www.cnblogs.com/xxflz/p/10444714.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!