一 点睛
HotSpot 的年轻代中除了拥有 ParNew 收集器是基于并行回收的以外,Parallel Scavenge 收集器同样也采用了复制算法、并行回收和"Stop the World"机制。
那么 Parallel 收集器的出现是否多此一举?
-
和 ParNew 收集器不同,Parallel Scavenge 收集器的目标则是达到一个可控制的吞吐量(Throughput),它也被称为吞吐量优先的垃圾收集器。
-
自适应调节策略也是 Parallel Scavenge 与 ParNew 一个重要区别。
高吞吐量则可以高效率地利用 CPU 时间,尽快完成程序的运算任务,主要适合在后台运算而不需要太多交互的任务。因此,常见在服务器环境中使用。例如,那些执行批量处理、订单处理、工资支付、科学计算的应用程序。
Parallel 收集器在 JDK1.6 时提供了用于执行老年代垃圾收集的 Parallel Old 收集器,用来代替老年代的 serial old 收集器。
Parallel old 收集器采用了标记-压缩算法,但同样也是基于并行回收和"stop-the-World"机制。
在程序吞吐量优先的应用场景中,Parallel 收集器和 Parallel old 收集器的组合,在 server 模式下的内存回收性能很不错。在 Java8 中,默认是此垃圾收集器。
二 参数配置
-XX:+UseParallel