码迷,mamicode.com
首页 > Web开发 > 详细

js闭包,原型,作用域等再一次理解

时间:2017-02-13 13:38:26      阅读:207      评论:0      收藏:0      [点我收藏+]

标签:赋值   return   无法   将不   全局   作用域   状态   自身   内存   

要理解闭包,原型等,首先要理解作用域

作用域:就是函数在定义的时候创建的,用于寻找使用到的变量的值的一个索引,而他内部的规则是,把函数自身的本地变量放在最前面,把自身的父级函数中的变量放在其次,把再高一级函数中的变量放在更后面,以此类推直至全局对象为止。

回收机制:一个函数在执行开始的时候,会给其中定义的变量划分内存空间保存,以备后面的语句所用,等到函数执行完毕返回了,这些变量就被认为是无用的了,对应的内存空间也就被回收了,下次再执行此函数的时候,所有的变量又回到最初的状态,重新赋值使用,但是如果这个函数内部又嵌套另一个函数,而这个函数是有可能在外部被调用的,并且这个内部函数又实用了外部函数的某些变量的话,这种内存回收机制就有问题了。如果在外部函数返回后,又直接调用了内部函数,那么内部函数就无法读取到他所需要的外部函数中的变量了。所有js解释器在遇到函数定义的时候,会自动把函数和他可能使用的变量(包括本地变量和父级和祖先级函数的变量(自由变量)一起保存起来,也就构建了一个闭包),这些变量将不会被内存回收器所回收,只有当内部的函数不可能被调用以后(例如被删除了,或者没有了指针),才会销毁这个闭包,而没有任何一个闭包引用的变量才会被下一次内存回收启动时所回收。

总结一下

  闭包外层是个函数。

  闭包内部都有函数。

  闭包会return内部函数。

  闭包返回的函数内部不能有return。(因为这样就诊的结束了)

  执行闭包后,闭包内部变量会存在,而闭包内部函数的内部变量不会存在

js闭包,原型,作用域等再一次理解

标签:赋值   return   无法   将不   全局   作用域   状态   自身   内存   

原文地址:http://www.cnblogs.com/maggie-pan/p/6393213.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!