JVM常用垃圾回收器的特性与使用场景
jvm垃圾回收器是GC算法的具体实现。常用的垃圾回收器有以下几种,并且分别针对的是堆内存中的新生代、老年代。值得一提的是方法区(有的文章也将之称为永久代,主要存放类信息、常量池、静态类变量等)也会触发GC,主要是回收不可存活的常量对象以及无用类(当该类在程序中不再存在任何实例、对应的classloader被卸载、该类的类对象class不被任何地方引用,此时可以被回收)。
1.Serial垃圾回收器
简要概括下该回收器的特点:单线程,基于复制算法,JVM运行在Client时默认的新生代垃圾收集器。
可以说Serial是最基本的垃圾回收器,使用的是复制算法,回收效率高,不容易产生不连续的内存碎片。并且也是单线程的垃圾回收器,只使用一个线程完成垃圾回收工作,并且此时会暂停其他工作线程。
2.ParNew垃圾回收器(serical+多线程版本)
简要概括下该回收器的特点:Serial的多线程实现,基于复制算法,JVM运行在Server时默认 的新生代垃圾收集器。
该垃圾回收器是Serial的多线程版本,采用的也是复制算法(毕竟都是作用于新生代嘛),也是在执行垃圾回收收集时需要暂停其他工作线程。
默认开启与CPU相同数目的线程数,可以通过参数-XX:ParallerGCThreads来修改默认开启的线程数量。
3.Parallel Scavenge垃圾回收器(多线程复制算法)
简要概括下该回收器的特点:多线程,基于复制算法,以吞吐量最大化为目标,允许较长时间的STW换取吞吐量。</