JavaScript 闭包浅谈

要想了解闭包,首先得对函数定义域有所了解。函数作用域,顾名思义就是在定义函数时候产生的作用域,这个作用域也可以称为局部作用域。函数作用域一般只在函数的代码片段内可访问到,外部不能进行变量访问。在函数内部定义的变量存在于函数作用域中,其生命周期随着函数的执行结束而结束。实例如下:

var test = "hello";
  
 function show() {
      var test = "nihao";
      console.log(test); // 输出:nihao
 }
 
show();
console.log(test); // 输出:hello,此时访问的是全局变量。


在javascript的世界里,作用域概念存在于函数中,当函数运行到某行代码需要查找某个变量时,编译器会在当前函数作用域下查找该变量,如果没有找到则继续往上一层函数作用域查找,这个过程会一直持续到全局作用域,如果没有找到相应变量,则抛出报错信息。闭包的官方定义为:一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。



概括来说:闭包就是一个函数,捕获作用域内的外部绑定。这些绑定是为之后使用而被绑定,即使作用域已经销毁。


下面是引用知乎上的一个例子进行解释。
var b = function(){
    var n = 12450
    var x = function(){ 
        alert(n)
    }
    x() //12450
    return x
}


var a = b()
a() //12450


var a = b()
执行了【函数b】,并把执行结果赋值给了【变量a】


【函数b】的执行结果:返回一个函数
由于函数是引用类型,所以实际上返回了指向【函数x】的地址


把【变量x(变量x是个指针)】的值赋值给【变量a】,【变量a】现在变成了指针,指向了【函数x】


由于【函数x】在【函数b】内,所以按照作用域规则,
在【函数x】内操作【变量n】,其实操作的是:【函数b】内的局部【变量n】




所以在这个例子中,【变量a】打破了作用域规则,引用到了【函数x】,成为了闭包。
而且【函数x】不会垃圾回收了。


至于闭包是否会导致内存外泄。IE6时代有bug,甚至IE8浏览器闭包仍会造成内存泄漏,但这个是浏览器本身的问题。其次,闭包本身不会造成内存泄漏,但闭包过多很容易导致内存泄漏,主要是程序代码的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值