JVM笔记

5.垃圾收集器

2019-11-18  本文已影响0人  雪关马不前

Serial收集器

单线程的收集器,“单线程”的意义并不仅仅说明它只会使用一个CPU或一条收集线程去完成垃圾手机工作,更重要的是在它进行垃圾收集时,必须暂停其他所有的工程线程,直到它手机结束。

ParNew收集器

ParNew是Serial收集器的多线程版本。

Parallel Scavenge收集器

它是一个新生代收集器,它也是使用复制算法的收集器,又是并行的多线程收集器。“吞吐量优先”收集器。

Serial Old收集器

是Serial收集器的老年代版本,同样是一个单线程收集器,使用“标记-整理”算法。

Parallel Old收集器

是Parallel Scavenge收集器的老年代版本,使用多线程和“标记-整理”算法。

CMS收集器

CMS(Concurrent Mark Sweep)收集器是一种以获取最短回收停顿时间为目标的收集器。它的运作过程相对于前面几种收集器来说更为复杂一些,整个过程分为4个步骤,包括:

初始标记(CMS initial mark)

并发标记(CMS concurrent mark)

重新标记(CMS remark)

并发清除(CMS concurrent sweep)

缺点:

对CPU资源非常敏感。在并发中执行GC时会因为占用了一部分CPU资源而导致应用程序变慢,总吞吐量会降低。

无法处理浮动垃圾(Floating Garbage),可能出现“Concurrent Mode Failure”失败导致另一次Full GC产生。

基于“标记-清除”算法实现,会产生大量空间岁票。造成对象分配麻烦。

G1收集器

G1(Garbage-First)收集器是当今收集器技术发展的最前沿成果之一。运作过程大致可以划分为以下几个步骤:

初始标记

并发标记

最终标记

筛选回收。

上一篇 下一篇

猜你喜欢

热点阅读