JVM—CMS收集器

参考资料:深入理解Java虚拟机:JVM高级特性与最佳实践(第3版)周志明

CMS收集器(Concurrent Mark Sweep)是一种以获取最短回收停顿时间为目标的收集器。低并发收集、低停顿。

  • CMS收集器是基于标记---清除算法实现的,它的运作过程分为四个步骤:
  1. 初始标记:标记GC Roots能直接关联的对象;该操作很快,需要暂停用户线程

  2. 并发标记:从GC Roots直接关联对象开始遍历整个对象图的过程。过程耗时长,但不会暂停用户线程,并且可以与 垃圾收集 线程并发运行。

  3. 重新标记: 重新标记则是为了修正并发标记期间,用户程序继续运作,导致标记变动的那一部分对象的标记记录。需要暂停用户线程,比初始标记长比并发标记短。

  4. **并发清除:**清理标记阶段判断已经死亡的对象,由于不需要移动存活对象,所以该过程也是与用户线程并发的。

CMS有以下三个明显缺点:

  1. CUP性能消耗:多开线程,使得CPU消耗增加。

  2. 浮动垃圾(Floating Garbage):由于GC线程和用户线程并发,在GC线程运行过程中产生的垃圾就叫浮动垃圾。这部分垃圾无法在当次收集中处理掉它,只好留到下一次 垃圾收集 中清理。

  3. 内存 碎片:CMS基于标记-清除算法,会产生大量的内存碎片,内存碎片过多会导致大对象的分配出现问题,严重的话会出现OOM。

相关推荐
攒了一袋星辰9 分钟前
JVM类加载过程
运维·服务器·jvm
tianyagukechat18 分钟前
rockylinux9.5 配置IP
java·网络·tcp/ip
程序员Sonder26 分钟前
黑马java----正则表达式(一文弄懂)
java·正则表达式·新人首发
doris820427 分钟前
Python 正则表达式 re.findall()
java·python·正则表达式
Anastasiozzzz41 分钟前
阿亮随手记:动态条件生成Bean
java·前端·数据库
丹牛Daniel1 小时前
Java解决HV000183: Unable to initialize ‘javax.el.ExpressionFactory‘
java·开发语言·spring boot·tomcat·intellij-idea·个人开发
消失的旧时光-19432 小时前
智能指针(三):实现篇 —— shared_ptr 的内部设计与引用计数机制
java·c++·c·shared_ptr
芒克芒克2 小时前
深入浅出CopyOnWriteArrayList
java
wuqingshun3141592 小时前
说一下java的反射机制
java·开发语言·jvm
A懿轩A2 小时前
【Java 基础编程】Java 异常处理保姆级教程:try-catch-finally、throw/throws、自定义异常
java·开发语言·python