9、闭包

浏览器的垃圾回收机制:
【谷歌浏览器】:基于 “引用查找 ”来进行垃圾回收。
1、开辟的堆内存,浏览器自己默认会在空闲的时候,查找所有内存的引用,
把那些不被引用的内存释放掉。
2、开辟的栈内存(上下文),一般在代码执行完都会释放掉,如果遇到上
下文中的东西被外部占用,则不会被释放。
【IE等低版本浏览器】:基于 “计数器机制”来进行内存管理。
1、创建的内存别引用一次,则计数1,再被引用一次,则计数2......,移除引用
减去1,当减为0的时候,浏览器会把内存释放掉。

真实项目中,某些情况导致计数规则会出现一些问题,造成很多内存不能被
释放掉,产生“内存泄漏”,查找引用的方式如果出现相互引用,也会导致“内存泄漏”

闭包:函数执行会形成全新的私有上下文,这个上下文可能被释放掉,也可能不被释放掉,
不论是否被释放,它的作用是:
1、保护:划分一个独立的代码执行区域,在这个区域中有自己私有变量的存储空间,
而用到的私有变量和其他区域中的变量不会有任何的冲突(防止全局变量污染)。
2、保存:如果上下文不被销毁,那么存储的私有变量的值也不会被销毁,可以被
其下级上下文中调取使用。
我们把函数执行,形成的私有上下文,来保存和保护私有变量的机制,称之为“闭包”
=> 闭包是一种机制

闭包.png
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容