【JVM-垃圾回收器】

一、串行垃圾回收器(SerialGC)

  • 单线程
  • 堆内存较小时,CPU个数少的,适合个人电脑
  • 开启串行垃圾回收器:"-XX:+UseSerialGC=Serial+SerialOld", 复制+老年代(标记加整理算法)

二、吞吐量优先垃圾回收器(并行ParallelGC)

  • 多线程
  • 堆内存较大,多核CPU,适合服务器
  • 让单位时间内,STW时间最短

三、响应时间优先垃圾回收器(CMS)

  • 多线程
  • 堆内存较大,多核CPU,适合服务器
  • 尽可能让单词STW时间最短

四、G1垃圾回收器

  • 定义

Garbage First

2004论文发布

2009 JDK 6u14体验

2012 JDK 7u4 官方支持

2017 JDK9 默认

  • 同时注重吞吐量、低延迟,默认的暂停目标时200ms
  • 超大堆内存,会将堆划分为多大小相等的Region
  • 整体上是标记+整理算法,两个区域之间是复制算法
  • 相关JVM参数如下
  1. G1垃圾回收阶段(young collection开始、循环过程)
  • 第一阶段:Young Collection(新生代)
  • 第二阶段:Young Collection + Concurrent Mark(新生代 + 并发标记)
    • 在Young GC时会进行GC Root的初始标记
    • 老年代占用堆空间比例达到阈值时,进行并发标记(不会STW),Young下面的 JVM参数决定
      -XX:InitiatingHeapOccupancyPercent=percent (默认是45%)
  • 第三阶段:Mixed Collection
    • 会对E、S、O进行全面垃圾回收
    • 最终标记(Remark)会STW
    • 拷贝存活(Evacuation)会STW
      -XX:MaxGCPauseMillis=ms

Full GC

相关推荐
源分享10 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
JAVA96510 天前
JAVA面试-JVM篇 03-JVM运行时数据区哪些是线程私有的哪些是共享的
java·jvm·面试
伶俜6611 天前
鸿蒙原生应用实战(十八)ArkUI 记账本:SQLite 账单 + 图表统计 + 分类管理
jvm·sqlite·harmonyos
IronMurphy11 天前
多线程问!
java·jvm·spring
unique11 天前
AI Coding 采集方案探索
jvm·人工智能·oracle
cfm_291411 天前
JVM GC日志解析
jvm
不良使11 天前
鸿蒙PC迁移:使用Electron`logseq-master-ohos` 鸿蒙适配全记录
jvm·electron·harmonyos
cfm_291412 天前
JVM深度详解:Class常量池、运行时常量池、字符串常量池、包装类对象池
java·jvm
JAVA96512 天前
JAVA面试-JVM篇 02-G1垃圾收集器的工作原理是什么与CMS的区别
java·jvm·面试