垃圾回收机制(GC)
js的垃圾回收是自动的,全局变量不可回收,GC可以找到内存中的垃圾,释放和回收空间
GC算法
GC回收时,查找和回收所依靠的规则
常用的有:引用计数,标记清除,标记整理,分代回收等
引用计数
工作原理:定义变量函数等时计数为0,每次引用后会加1,结束引用会减1,当归0时,会被回收
优点:发现垃圾会立即回收,可以减少程序暂停
缺点:循环引用时,永远不会为1,不会回收,并且耗时
标记清除算法
标记清除算法:在全局开始查找可达对象,并把可达对象均标记,然后查找完,再清除没有标记过的对象
优点:可解决循环引用不能回收
缺点:空间碎片化,不能很好的利用清除后的空间,不会立即清除垃圾,需要等到标记全部结束再清除,清除时,程序会停止
标记整理
标记整理即在标记的基础上,清除阶段前,会先整理清除对象的位置,使他们的存储位置连续,然后再清除
V8引擎
主流的js的执行引擎,采用即时编译,存在内存上限
V8垃圾回收
主要采用分代回收,复制算法,标记清除,标记整理,