JVM学习笔记-垃圾回收器

这篇文章,我会介绍两个回收器 ParNew和CMS

ParNew回收器

ParNew这个回收期主要用于MinorGC回收
它回收的速度很快,是一个多线程回收器,比Serial回收器(单线程)效率要快得多。
使用 -XX:+UseParNewGC 可以开启ParNew垃圾处理器
使用 -XX:ParallelGCThreads 可以调节垃圾回收器的线程数量

CMS回收器

CMS主要用于老年代回收器,它主要的回收算法是标记清理算法。
标记清理算法是将与GC关联的存活变量打上标记,其余的被回收。
它的缺点在于会造成很多内存碎片,这些碎片又因为空间很小不足以支撑新的变量进入。

CMS回收器的回收步骤
初始标记

这是第一步,将GC相关联的存活变量打上标记,因为进入老年代存活变量很少,虽然这一步会执行StopTheWorld,但是速度很快,无伤大雅。

并发标记

这是第二步,此时此刻创建新变量继续追踪GC相关对象

重新标记

这时系统会执行StopTheWorld,将新创建的对象进行重新标记,但是速度很快,无伤大雅

回收清理

清理之前标记为垃圾的对象,这个操作很耗时,但是因为是并发操作,并不影响系统运行

回收清理过程中产生的新的垃圾,我们称之为浮动垃圾
那么CMS是标记清理算法,内存碎片过多该如何控制呢?
首先有个参数-XX:+UseCMSCompactAtFullCollection可以对第N次老年代FullGC之后进行一次碎片整理的控制,控制其内存整理时机问题

你可能感兴趣的:(JVM,算法,jvm,java,多线程,jdk)