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。

相关推荐
一 乐17 小时前
社区互助|社区交易|基于springboot+vue的社区互助交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·小区互助系统
q***577418 小时前
Spring Boot 实战:轻松实现文件上传与下载功能
java·数据库·spring boot
q***563818 小时前
Spring Boot 集成 Kettle
java·spring boot·后端
stevenzqzq18 小时前
android recyclerview缓存_缓存问题解决办法
android·java·缓存
武子康18 小时前
Java-174 FastFDS 从单机到分布式文件存储:实战与架构取舍
java·大数据·分布式·性能优化·系统架构·dfs·fastdfs
失散1318 小时前
分布式专题——56 微服务日志采集与分析系统实战
java·分布式·微服务·架构
失散1318 小时前
分布式专题——57 如何保证MySQL数据库到ES的数据一致性
java·数据库·分布式·mysql·elasticsearch·架构
会编程的吕洞宾18 小时前
Java Set集合:你的数据去重神器
java·后端·程序员
q***656918 小时前
Spring Data 什么是Spring Data 理解
java·后端·spring
WYS@不忘初心18 小时前
在Eclipse IDE for Embedded C/C++ Developers软件中定义的宏,编译C源文件时编译器无法找到宏定义!
java·ide·eclipse