JavaScript 闭包

JavaScript 闭包

1.什么是闭包?

简单来说,闭包是访问一个函数作用域变量的函数,一般定义在外层函数中的内层函数。

2.为什么需要闭包呢?

局部变量无法长久的共享和长久的保存,而全局变量会造成全局变量污染,因此,我们希望有一种机制可以长久的保存变量,又不污染全局变量。

2.特点

(1)占用更多内存  (2)不容易释放 (3)可以有效的共享和保存局部变量

3.何时使用?

即想反复使用,又想避免全局变量污染

4.如何使用?

(1)定义外层函数,封装被保护的局部变量

(2)定义内层函数,执行对外部变量的操作

(3)外层函数返回内层函数的对象,并且外部函数被调用,结果保存在一个全局或者局部的变量中

5.闭包函数的生命周期

(1)定义时,创建作用域函数对象,创建函数对象

(2)调用时,创建一个活动的对象,将活动对象的引用追加到作用域链对象中,创建执行环境

(3)调用后,活动对象释放,作用域链中的活动对象引用出栈,执行环境出栈

6.实例说明

let getNum;//------------------------(1)
function getCounter() { 
    var n = 1; 
    var inner = function () { 
        return n++; 
    }
    return inner;
}// --------------------------------(2)

getNum = getCounter();//------------(3)
console.log(getNum()); //1 ---------(4)
console.log(getNum()); //2 ---------(5)

在程序运行到(2)步的时候,创建了全局的函数对象和作用域函数对象 对应上面 5.闭包的函数的生命周期 中的(1)步

函数对象是 getCounter ,作用域链对象是getNum, ;

在程序执行到(3)步的时候,getCounter 把活动的对象赋给作用域链对象

在程序执行到(4)步的时候,创建了执行函数的环境,活动对象返回对应的数据,在作用域链中活动对象出栈,执行环境出栈。

在程序执行到(5)步的时候,同上。

7.总结

可以看到,内层函数对象被全局变量getNum引用和外层函数活动对象引用,内层函数对象在函数调用完,无法被内存回收,因此占用了更多的内存空间,但是这样确持久的保存了n的值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值