javascript中的垃圾回收历史有两种,一种是最常用的标记清除,一种是不常用的引用计数清除法。
标记清除
标记清除是现代浏览器最常用的垃圾回收方式,原理是:
当上下文有变量进入的时候就为它添加一个标记,这样整个程序执行时每一个创建的变量都会被添加标记。当变量离开上下文时也会被加上离开上下文的标记。然后当垃圾回收进程执行时,会把当前上下文的所有变量跟被引用的变量去除标记,这样剩下的有标记就都是不被引用也不被使用的变量了,这样就可以做内存清理了,销毁带标记的值并回收内存。
引用计数清除
这种计数方式在早期浏览器有使用过,后面就基本不怎么使用了,原理如下:
当一个值被赋值给一个变量时就会把该值的引用数加一。比如,当声明一个变量并引用该值,则该值的引用数加一,当这个值被赋给另一个变量时,引用数继续加一。当一个引用该值的变量被其他值覆盖了,则该值的引用数减一,当引用数为0则表示该值不可被访问了,就会被垃圾回收。
该方式不常用是因为在循环引用时会无法释放内存,比如当a是一个对象,b也是一个对象,a的某个属性指向了b,b的某个属性指向了a,这样他们的引用值一直都不会为0,也就导致了该值一直存在无法回收。只有当我们显示的将a对应的属性跟b对应的属性都赋值null才会让他们进入垃圾回收。