CMS(Concurrent Mark Sweep)和G1(Garbage-First)都是Java的垃圾回收器。
CMS是一种并发标记清除算法,它采用多线程并发清除,可以在不暂停应用程序的情况下进行垃圾回收。
CMS的回收过程分为以下阶段:
-
初始标记阶段:在这个阶段中,收集器会暂停程序的执行,标记出直接被根对象引用的对象。
-
并发标记阶段:在这个阶段中,收集器可以并发标记所有可达的对象,不需要暂停应用程序。
-
重新标记阶段:在应用程序运行期间,收集器继续标记新生成的对象,直到所有对象都被标记为可达或不可达。
-
并发清除阶段:在这个阶段中,收集器可以并发清除不可达对象,不需要暂停应用程序。
相比于其他垃圾回收算法,CMS具有较短的回收时间和较小的暂停时间。但是,CMS也存在某些缺点,如在运行过程中需要占用一定的CPU资源,可能会导致部分应用程序性能下降。
G1垃圾回收器是一种基于分代的简单垃圾回收器,它将整个Java堆划分为许多大小相等的区域,称为“区域”。
G1的回收过程分为以下几个步骤:
-
初始标记阶段:和CMS一样,这个阶段需要暂停程序的执行,标记出直接被根对象引用的对象。
-
并发标记阶段:和CMS一样,这个阶段中,G1收集器并发地标记所有可达的对象。
-
最终标记阶段:在这个阶段中,收集器扫描堆并且标记所有未被标记的存活对象。
-
筛选回收阶段:在这个阶段中,收集器根据区域的回收价值进行排序,以便选择价值最低的区域进行垃圾回收,这样可以保证回收效率。
相较于CMS,G1的优势在于它可以控制暂停时间,避免应用程序停顿过长时间,同时还具有高回收效率、低内存使用和更好的可预测性等优点。