JVM常见垃圾回收器

串行垃圾回收器

Serial和Serial Old串行垃圾回收器,是指使用单线程进行垃圾回收,堆内存较小,适合个人电脑

  • Serial作用于新生代,采用复制算法

  • Serial Old作用于老年代,采用标记-整理算法

垃圾回收时,只有一个线程在工作,并且java应用中的所有线程都要暂停(STW),等待垃圾回收完成

并行垃圾回收器

Parallel New 和 Parallel Old是一个并行垃圾回收器,JDK8默认使用此垃圾回收器

  • Parallel New作用于新生代,采用复制算法

  • Parallel Old作用于老年代,采用标记-整理算法

垃圾回收时,多个线程在工作,并且java应用中的所有线程都要暂停(STW),等待垃圾回收的完成

CMS(并发)垃圾回收器

CMS1一款并发 的,使用标记-清除 算法的垃圾回收器,该回收器是针对老年代垃圾 回收的,是一款以获取最短回收停顿时间为目标的收集器,停顿时间段,用户体验就好。其最大特点是在进行垃圾回收时,应用仍能正常运行。

G1(Garbage first)垃圾回收器

  • 应用于新生代和老年代,在JDK9之后默认使用G1

  • 划分成多个区域,每个区域都可以充当Eden、survivor、old、humongous,其中humongous专为大对象设计

  • 采用复制算法(划分多个区域就是为了采用复制算法)

  • 响应时间与吞吐量兼顾

  • 分成三个阶段:新生代回收、并发标记、混合收集

  • 如果并发失败(即回收速度赶不上创建新对象的速度),会出发Full GC

Young Collection

  • 初始化时,所有区域都处于空闲状态

  • 创建了一些对象,挑出一些空闲区域作为伊甸园区存储这些对象

  • 当伊甸园需要垃圾回收时,跳出一个空闲区域作为幸存区,用复制算法复制存活对象,需要暂停用户线程

  • 随着时间流逝,伊甸园的内存又有不足

  • 将伊甸园以及之前的幸存区中的存活对象,采用复制算法,复制到新的幸存区,其中较老对象晋升至老年代

YoungGC+Concurrent Mark(年轻代垃圾回收+并发标记)

  • 当老年代占用内存超过阈值(默认是45%)后,触发并发标记,这时无需暂停用户线程。

  • 并发标记之后,会有重新标记阶段解决漏标问题,此时需要暂停用户线程。(STW时间较短)

  • 重新标记完成后就知道老年代有哪些存活对象,随后进入混合收集阶段。 此时不会对所有老年代区域进行回收,而是根据暂停时间目标优先回收价值高(存活对象少) 的区域。(这就是Gabage First名称的由来 垃圾多的区域优先)

相关推荐
@LetsTGBot搜索引擎机器人31 分钟前
Telegram 被封是什么原因?如何解决?(附 @letstgbot 搜索引擎重连技巧)
开发语言·python·搜索引擎·机器人·.net
沐欣工作室_lvyiyi2 小时前
基于Matlab的简易振动信号分析系统(论文+仿真)
开发语言·matlab·毕业设计·振动信号分析
2401_841495642 小时前
【数据结构】基于Prim算法的最小生成树
java·数据结构·c++·python·算法·最小生成树·prim
木井巳4 小时前
[Java数据结构和算法] HashMap 和 HashSet
java·数据结构·1024程序员节
祈祷苍天赐我java之术5 小时前
解析常见的限流算法
java·数据结构·算法
摇滚侠5 小时前
IDEA 启动前端项目 IDEA 切换分支
java·ide·intellij-idea
元直数字电路验证5 小时前
Jakarta EE开发中,如何配置IntelliJ IDEA的远程调试?
java·eureka·intellij-idea
石头wang5 小时前
idea字体的问题(idea应用本身的字体问题)
java·ide·intellij-idea
liu****5 小时前
1.模拟算法
开发语言·c++·算法·1024程序员节
数据村的古老师5 小时前
Python数据分析实战:基于25年黄金价格数据的特征提取与算法应用【数据集可下载】
开发语言·python·数据分析