CMS一直是面试中的常考点,今天我们用通俗易懂的语言简单介绍下。


垃圾回收器为什么要分区分代?


如上图:JVM虚拟机将堆内存区域分代了,先生代是朝生夕死的区域,老年代是老不死的区域,不同的年代对象有不同特性,因此需要不同的垃圾收集器去处理。如下图,黑竖线左边的区域都是分代垃圾收集器,G1之后内存就不分代了。



单线程垃圾收集器:Serial + Serial Old


Serial(SY),Serial Old(SO)是单线程垃圾收集器组合,垃圾收集线程是单线程的,随着现代内存区域越来越大,SY+SO组合已经越来越少了。垃圾收集的单线程需要STW时间无疑越长。这种组合比较合适较早JDK版本。如下图,用户线程表示应用程序处理过程,垃圾收集线程表示垃圾线程清理垃圾过程,此阶段应用程序是需要等待垃圾线程STW的。


多线程垃圾收集器:PS+PO


前面我们说了,单线程垃圾收集器缺点就是当内存区域变大,收集效率会很低,那OK,摇身一变,如下图,多线程垃圾处理器。

值得注意的是:PS+PO组合是JDK1.7,JDK1.8默认垃圾收集器。通过java -XX:+PrintCommandLineFlags命令可以在Dos界面查看。如下图,该命令可以查看JVM初始化的默认参数。比如:-XX:InitialHeapSize表示初始化堆大小。


为啥蹦出来个CMS+ParNew


并行处理有了,CMS+ParNew又是干嘛的?其实PO关注是吞吐量,而CMS关注是缩短STW时间。而CMS处理流程更复杂,至于ParNew,其实约等于PS,如果你注意最上面一个图,你会发现PS年轻代无法和CMS组合。所以就多出来了一个ParNew。


介绍CMS阶段


CMS,全名称Concurrent Mark Sweep,中文释义并发标记清除,从名字上可以看出算法思想使用标记清除算法,下面我们看看CMS简化处理流程。

  • 初始标记。只标记GC root可达的第一个节点。会短暂的STW。
  • 并发标记。用户线程和垃圾线程同时进行。垃圾线程会继续向下寻找GCroot,不会有STW。但也会有两个问题。
    • 多标:之前不是垃圾,现在线程出栈引用断开了变成了垃圾。也称为浮动垃圾。
    • 错标:之前已经被标注是垃圾,但现在重新引用。
  • 重新标记。STW时间一般低于200毫秒。
  • 并发清除。并发清除时,因为用户线程和垃圾线程一起工作,如果CMS线程异常,可能会触发SO单线程执行。程序可能会特别缓慢。

劣势:碎片严重。


总结


主要简单介绍了分代垃圾回收器,特别介绍了cms执行过程,G1留下次再说吧。好了,文章有地方还写的不清晰希望亲们加以指正和点评,喜欢的请点赞加关注哦。点关注,不迷路,我是叫练,边叫边练,公众号叫练,微信号【jiaolian123abc】。祝大家生活愉快。


©著作权归作者所有:来自51CTO博客作者叫练的原创作品,如需转载,请注明出处,否则将追究法律责任

你的鼓励让我更有动力

赞赏

0人进行了赞赏支持

更多相关文章

  1. Mysql主从复制
  2. 《吊打面试官》系列-ConcurrentHashMap & Hashtable
  3. 记一次线程池引发的故障 排查下来是三歪的锅
  4. 程序员专享绿色独角兽Gunicorn,了解下
  5. HBase实战 | 排查HBase堆外内存溢出
  6. 技术分享:Java多线程学习处理高并发问题
  7. AQS
  8. 可重入锁
  9. 解决redis消息通知造成大量redisMessageListenerContainer线程

随机推荐

  1. 铯:使用自己的OpenStreetMap服务器。:“
  2. Linux下动态链接库创建问题
  3. linux内核模块的强制删除-结束rmmod这类d
  4. WinSCP 中普通用户以 root 身份登录 Linu
  5. 使用cobbler实现批量自动部署Linux
  6. 使用.NetCore在Linux上写TCP listen 重启
  7. LinuxShell编程学习日记
  8. linuxi学习curses(3) 学习输入
  9. 【原】记一次找回mac root账号的苦逼经历
  10. linux 通过wol远程开机【转】