ParNew是用于新生代的并行多线程垃圾收集器,采用“复制”算法,与"Parallel Scavenge"使用的算法相同。它与“ Parallel Scavenge”的不同之处在于,它具有使其可以在CMS中使用的增强功能。例如,“ ParNew”执行所需的同步,以便它可以在CMS的并发阶段运行。
图3-1:并行多线程垃圾收集过程示意图
从上图可以看出,其在STW阶段运行的GC是多线程的,这与Serial收集器的单线程形成鲜明对比。
复制算法
复制算法也是包含“标记”阶段的,所以我们叫它“标记-复制”算法更为准确。“标记-复制”算法与“标记-整理”算法非常相似,因为它们也可以重新放置所有活动对象。重要的区别是,重定位的目标是一个不同的内存区域,作为被标记为活动对象的新家。标记-复制方法具有一些优点,因为复制可以在同一阶段与标记同时进行。缺点是需要另外一个存储区域,该存储区域应足够大以容纳活动对象。