JVM 的标记清除垃圾回收算法

标记-清楚(Mark-Sweep)算法,分为“标记”和“清除”两个阶段:首先标记出所有需要回收的对象,在标记完成后统一回收掉所有被标记的对象。之所以说它是最基础的收集算法,是因为后续的收集算法都是基于这种思路并对其缺点进行改进而得到的。大多数主流虚拟机采用可达性分析算法来判断对象是否存活,在标记阶段,会遍历所有 GC ROOTS,将所有 GC ROOTS 可达的对象标记为存活。只有当标记工作完成后,清理工作才会开始。
    它的主要缺点有两个:
        (1)效率问题:标记和清除过程的效率都不高;
        (2)空间问题:标记清除之后会产生大量不连续的内存碎片,空间碎片太多可能会导致,碎片过多会导致大对象无法分配到足够的连续内存,从而不得不提前触发GC,甚至Stop The World。

理解这种思想会帮助我们去实现很多算法。就像数组的删除,实际在删除数组中的某些元素时,在某些特定的场景下,我们为了避免数据搬移而产生效率问题,可以不保持数据的连续性的情况下,可以整体记录将要删除的元素,每次的删除操作并不是真正地搬移数据,只是记录数据已经被删除。当数组没有更多空间存储数据时,我们再触发执行一次真正的删除操作,这样就大大减少了删除操作导致的数据搬移。

你可能感兴趣的:(java)