浏览器的垃圾回收机制:
【谷歌浏览器】:基于 “引用查找 ”来进行垃圾回收。
1、开辟的堆内存,浏览器自己默认会在空闲的时候,查找所有内存的引用,
把那些不被引用的内存释放掉。
2、开辟的栈内存(上下文),一般在代码执行完都会释放掉,如果遇到上
下文中的东西被外部占用,则不会被释放。
【IE等低版本浏览器】:基于 “计数器机制”来进行内存管理。
1、创建的内存别引用一次,则计数1,再被引用一次,则计数2......,移除引用
减去1,当减为0的时候,浏览器会把内存释放掉。
真实项目中,某些情况导致计数规则会出现一些问题,造成很多内存不能被
释放掉,产生“内存泄漏”,查找引用的方式如果出现相互引用,也会导致“内存泄漏”
闭包:函数执行会形成全新的私有上下文,这个上下文可能被释放掉,也可能不被释放掉,
不论是否被释放,它的作用是:
1、保护:划分一个独立的代码执行区域,在这个区域中有自己私有变量的存储空间,
而用到的私有变量和其他区域中的变量不会有任何的冲突(防止全局变量污染)。
2、保存:如果上下文不被销毁,那么存储的私有变量的值也不会被销毁,可以被
其下级上下文中调取使用。
我们把函数执行,形成的私有上下文,来保存和保护私有变量的机制,称之为“闭包”
=> 闭包是一种机制