CMS、G1、ZGC

CMS

在java中,可作为GC Roots的对象有:

1.虚拟机栈(栈帧中的本地变量表)中引用的对象;

2.类静态属性引用的对象;

3.常量引用的对象;

4.本地方法栈中JNI(即一般说的Native方法)中引用的对象

回收线程数是(CPU数量+3)/4,

Java5开始使用的一款垃圾回收器,它是一个老年代垃圾回收器,可以和Serial收集器,Parallel New收集器配合使用。

cms它是一款专注于减少停顿时间的一款垃圾回收期

它有四个阶段:

  • 初始标记(标记GcRoots直接相连的对象)
  • 并发标记
  • 重新标记(新生代晋升到老年代的对象,直接分配到老年代的对象,引用变更)
  • 垃圾清理
    并发标记还有垃圾清理的时候,用户线程可以执行,不需要停顿
    CPU敏感、CPU敏感、CPU敏感
    浮动垃圾
    空间碎片,空间碎片多了,给大对象的分配带来麻烦

G1

Java7引入

特点:

1.并行与并发

G1 能充分利用多CPU、多核环境下的硬件优势,使用多个垃圾收集线程同时进行垃圾回收工作,减少垃圾回收的停顿时间

2.分 Region 的内存布局

G1 将堆内存分为多个大小相等的独立区域 Region,每个 Region 都可以扮演Eden、Survivor、Old 区的角色,这样可以不像其他垃圾回收器那样整个代进行回收,它是对Region进行回收

3.可预测的停顿时间

G1 可以建立可预测的停顿时间模型,用户可以指定一个期望的停顿时间,G1 会根据这个目标来调整垃圾回收的策略,尽量保证每次垃圾回收的时间不超过设定的停顿时间

工作过程

1.初始标记(Initial Mark)

  • "首先会进行一个短暂的初始标记阶段,这个阶段会标记从 GC Roots 直接可达的对象,这个过程是 STW(Stop The World)的,但由于只需要标记从 GC Roots 直接可达的对象,所以速度很快。"
    2.并发标记(Concurrent Marking)
  • "接着进入并发标记阶段,这个阶段可以与应用程序线程同时运行。在这个阶段,G1 会从初始标记的对象出发,遍历对象图,标记所有可达的对象。这个过程中应用程序可以继续执行,不会被完全暂停。"
    3.最终标记(Final Mark)
  • "在并发标记结束后,需要进行一个最终标记阶段,这个阶段也是 STW 的。在这个阶段中,G1 会处理在并发标记阶段中可能被修改的对象的标记,确保标记的准确性。"
    4.筛选回收(Live Data Counting and Evacuation)
  • "最后是筛选回收阶段,这个阶段会根据各个 Region 的回收价值和成本进行排序,选择回收价值最大的一些 Region 进行回收。在这个阶段中,G1 会把存活的对象复制到新的 Region...
    G1三种垃圾回收策略的概念与触发条件
    三种方式分别是什么含义
  • 新生代回收(YGC): 只回收新生代区域,代价低/频率高。
  • 混合回收(MixGC): 回收全部新生代+部分老年代,频率一般。
  • 完全回收(FullGC): 全部堆空间,代价高/频率低,系统离崩溃不远了。
相关推荐
yyt_cdeyyds5 分钟前
FIFO和LRU算法实现操作系统中主存管理
算法
xmh-sxh-131415 分钟前
jdk各个版本介绍
java
alphaTao31 分钟前
LeetCode 每日一题 2024/11/18-2024/11/24
算法·leetcode
天天扭码34 分钟前
五天SpringCloud计划——DAY2之单体架构和微服务架构的选择和转换原则
java·spring cloud·微服务·架构
程序猿进阶35 分钟前
堆外内存泄露排查经历
java·jvm·后端·面试·性能优化·oom·内存泄露
FIN技术铺39 分钟前
Spring Boot框架Starter组件整理
java·spring boot·后端
kitesxian40 分钟前
Leetcode448. 找到所有数组中消失的数字(HOT100)+Leetcode139. 单词拆分(HOT100)
数据结构·算法·leetcode
小曲程序1 小时前
vue3 封装request请求
java·前端·typescript·vue
陈王卜1 小时前
django+boostrap实现发布博客权限控制
java·前端·django
小码的头发丝、1 小时前
Spring Boot 注解
java·spring boot