垃圾回收器进行回收时,会停止Java系统的所有工作线程,禁止创建对象,进入“Stop the World”状态。所以无论是新生代GC还是老年代GC,都要避免频率过高、持续时间过长,影响系统正常运行。
1、新生代垃圾回收器–ParNew
使用多线程垃圾回收机制,默认设置的垃圾回收线程数量是和CPU的核数是一样的,标记转移Eden和Survivor1的对象到Survivor2中去,然后尽快一次性回收掉Eden和Survivor1中的垃圾对象,回复Java工作线程的运行。
2、老年代垃圾回收器–CMS
一般老年代选择CMS垃圾回收器,采用标记清理算法,先通过追踪GC Roots的方法,如果对象没有对GC Roots引用,则标记为垃圾对象,然后一次性把垃圾对象都回收掉。为了避免“Stop the World”引起的系统卡死,CMS垃圾回收器采取垃圾回收线程和系统工作线程尽量同时执行的模式。
CMS在执行一次垃圾回收一共分为四个阶段:以下面的代码为例
初始标记
初始标记阶段会进入“Stop the World”状态,标记出所有GC Roots直接引用的对象,方法的局部变量和静态变量是 GC Roots,但类的实例变量不是GC Roots。