大部分浏览器以此方式进行垃圾回收,当变量进入执行环境(函数中声明变量)的时候,垃圾回收器将其标记为“进入环境”,当变量离开环境的时候(函数执行结束)将其标记为“离开环境”,在离开环境之后还有的变量则是需要被删除的变量。标记方式不定,可以是某个特殊位的反转或维护一个列表等。
//标记清除算法由以下步骤组成:
1.垃圾回收器构建”roots”列表。Roots通常是代码中保留引用的全局变量。在JavaScript中,”window”对象可以作为 root 全局变量示例。
2.所有的”roots”被检查并标记为active(即不是垃圾)。所有的children也被递归检查。从”root”能够到达的一切都不被认为是垃圾。
3.所有不被标记为active的内存可以被认为是垃圾了。收集器限制可以释放这些内存并将其返回到操作系统。