垃圾收集器

新生代垃圾收集器:
Serial收集器
单线程收集器,当它在进行垃圾收集时,必须暂停其他所有的工作线程。
ParNew收集器
ParNew是Serial收集器的多线程版本,除了使用多条线程进行垃圾收集之外,其他行为包括可用的所有控制参数、收集算法、回收策略等都与Serial收集器一样
Parallel  Scavenge收集器(吞吐量优先收集器)
Parallel  Scavenge收集器的特点是:达到最大吞吐量。所谓吞吐量就是CPU用于运行用户代码的时间与CPU总消耗时间的比值。
高吞吐量可以最高效率地利用CPU时间,尽快地完成程序的运行任务,主要适合后台运算而不需要太多交互的任务。

老年代垃圾收集器:
Serial Old收集器
单线程收集器,使用“标记-整理”算法
Parallel  Old收集器(吞吐量优先收集器)
使用多线程和“标记-整理”算法,这个收集器是JDK1.6中才开始提供的。
CMS(Concurrent Mark Sweep)收集器
CMS收集器是一种以获取最短回收停顿时间为目标的收集器,采用“标记-清除”算法
优点:并发收集、低停顿。缺点:CMS是一款基于“标记-清除”算法的收集器,收集结束时会产生内存碎片.
通过配置参数:-XX:+UserCMSCompactAtFullCollection 使虚拟机在执行完Full GC后,进行碎片整理。
-XX:CMSFullGCsBeforeCompaction该参数用于设置在执行多少次不压缩的Full GC后,执行一次带压缩的GC。
G1收集器 (Garbage First)   
G1收集器可以实现在基本不牺牲吞吐量的前提下完成低停顿的内存回收。暂没有提供可以商用的版本

你可能感兴趣的:(垃圾收集)