【Java 快速复习】垃圾回收算法 垃圾回收器

news2025/1/22 19:02:35

快速理解 Java 垃圾回收算法 & 垃圾回收器

先说个关系概念,垃圾回收的算法是逻辑概念的定义,用于规范垃圾回收器实现方的一些行为,而垃圾回收器就是实现这些算法的工具,这些工具大概是一系列的 C++ 的类以及其实现的一些对应回收算法。

分代和对象流转

基本上我们常用的垃圾回收算法对于堆空间都会有 分代 这一概念,通常来说分为 年轻代老年代

在这里插入图片描述

年轻代又下分 eden 区 和 survive0 和 survive1 区。对于一个新的对象一般来说会先进入年轻代的 eden 区,在对象的对象头 Mark Word 中会记录其分代年龄,最大是 15 (只给了 4 bit 位来存),默认也是 15。

通常我们说 GC 的时候又分为 年轻代的 GC 即 young gc 和 老年代的 GC 即 full gc,一般来说 young gc 耗时远低于 full gc 。我们优化堆空间分配的过程就是要尽量避免 full gc 的过程。

在 young gc 的过程中,会对年轻代区域的对象进行清理回收,存活下来的由 eden 进入 s0 ,或者由 s0 进入 s1 (或者 s1 进入 s0 这个是标记复制的过程)

每次 young gc 存活下来的对象分代年龄就会 +1,当达到 15 时(这个可以配置)。会将其移进老年代,不在参与之后的 young gc

这意味着老年代的对象一般应该是存活时间较长的对象。

9

基本的回收算法

标记复制

标记复制,准备两部分区域,这两部分区域实际使用只会用一部分,另一部分作为待复制空间。在垃圾回收过程中,将所有非垃圾对象直接复制到另一区域,本区域清空。 此算法清理速度较快,但空间利用率较低。

在这里插入图片描述

标记清理

标记清理算法比较暴力,标记好垃圾对象后直接将垃圾对象删除,这个速度也是很快的,但是会产生较多的内存碎片,进而可能影响后续的空间分配
在这里插入图片描述

标记整理

标记整理算法相对于标记清理算法多了一步整理,这不整理会将清理后碎片化的空间整理为连续空间,当然付出的代价是整理的耗时。
在这里插入图片描述

初级垃圾回收器 Serial & Parallel

Serial -XX:+UseSerialGC -XX:+UseSerialOldGC

Serial 收集器是最基础的垃圾收集器,其收集过程为单线程收集,适用于单核 CPU ,或者垃圾回收异常情况的备选方案,逻辑简单高效。

该收集器在垃圾回收过程中会全程 STW (Stop The Word 仅垃圾回收线程工作,其他线程暂停,即用户服务不可用)

年轻代使用算法:标记复制

老年代使用算法:标记整理

Parallel -XX:+UseParallelGC(年轻代),-XX:+UseParallelOldGC(老年代)

Parallel 相当于是 Serial 的多线程版,多线程收集效率更高 STW 时间更短,适用于多核 CPU, 4G 左右内存回收都是 OK 的。

年轻代使用算法:标记复制

老年代使用算法:标记整理

进阶常用垃圾收集器 ParNew + CMS & G1

ParNew -XX:+UseParNewGC

这个玩意,和 Parallel 是一样的,它的诞生是为了兼容配合 CMS 进行垃圾收集,CMS 是老年代的垃圾收集器,它只负责老年代的垃圾收集。

CMS

重头戏,CMS 是 Concurrent Mark Sweep 并发标记清除 ,CMS 进行垃圾回收分以下步骤

  1. 初始标记 STW:时间短,标记快,仅标记 gc roots 根对象
  2. 并发标记:二阶段标记,开始遍历 gc roots 引用的对象并进行标记,耗时较长但不会 STW 可以和用户线程同时运行
  3. 重新标记 STW:三阶段标记,收拾二阶段并发标记的残局,修正一些用户线程导致的对象引用变化
  4. 并发清理:清理,新增的垃圾不会处理,所以可能有浮动垃圾,但我觉得吧可以接受
  5. 并发重置:重置此次 GC 的标记数据

CMS 对于 8G 以内的内存处理表现良好,高于 8G 推荐使用 G1

大家应该看出来了,垃圾收集器的迭代在于想优化 STW 的时间,使其尽量短或者可控

G1 我公司线上服务就配置的这个

Garbage First 这个适用于大内存的垃圾收集 32G 以内效果比较好 (PS 不建议内存分配超过 32G 内存,否则默认的指针压缩将会失效)

并且 G1 在区域划分上进行了改变,它将整个堆空间划分为多个 Region 区域默认是堆大小除以 2048,而分代的区域不再是固定的区域,而是随着垃圾收集动态调整。并增加了大对象区的概念,如果一个对象被认定为大对象(超出 Region 区的 50%)则直接放到大对象区 Humongous 此区域会在 full gc 时回收

G1 垃圾回收对于 CMS 的优点就是可控的 STW 时间,并且因为没有物理隔离年轻代、老年代、存活区,G1 的所有垃圾回收方式都可以使用标记复制进行,速度极快

G1 垃圾回收分为以下过程:

  1. 初始标记 STW:速度极快
  2. 并发标记
  3. 重新标记 STW
  4. 筛选回收 STW:这个阶段 G1 将根据用户期望的 STW 时间进行选择性的回收,在用户期望 STW 停顿时间内回收最具性价比的垃圾。

G1 的垃圾收集分三类

young gc : eden 区满切预计回收时间接近 -XX:MaxGCPauseMills 配置的暂停时间则进行新生代回收,否则尝试扩容 eden 区

mixed gc : 混合 gc 在收集区域上类似 CMS 的 full gc ,会回收 young 和 old 以及 humongous

full gc: 这个更像是最终解决方案,当 mixed gc 都无法正常释放空间时,将进入并发失败进行单线程的 full gc 全程 STW

之前些了篇详解感兴趣可以看看,这里不在赘述 JVM 垃圾收集器 G1 详解

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/59523.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux服务器上跑深度学习实验

原文地址:Linux上跑深度学习实验 目录远程连接环境搭建与服务器断开连接后代码停止之前一直使用Google Colab跑实验,因为实验的规模不大,配合Google Drive用起来就很舒服,但是最近要系统地进行实验,规模一下子上来了&a…

【Spring】一文带你搞懂Spring容器配置

前言 本文为大家介绍的是Spring容器配置相关知识,包含Bean和Configuration的使用,使用 AnnotationConfigApplicationContext实例化Spring容器,Bean注解的使用,Configuration的使用,Import 注解的使用,结合J…

C++中STL-set详解

目录 set/ multiset容器 1. set基本概念 2.set构造和赋值 3.set大小和交换 4.set插入和删除 5.set容器-查找和统计 6.set和multiset的区别 7.pair对组创建 8.set容器排序 9.set存放自定义数据类型 set/ multiset容器 1. set基本概念 简介: 所有元素都会在插入时自动…

使用Apisix打造家庭NAS网关,免公网IP访问

使用Apisix打造家庭NAS网关 本文使用apisix打造家庭NAS网关,并通过cloudflare进行穿透,可免公网IP访问。首先你的NAS支持Docker,没有NAS也没有关系,只要你的电脑支持Docker同样可以参照该教程。 1 依赖资源准备 准备域名: 免费…

HTML+CSS+JS做一个好看的个人网页—web网页设计作业

个人网页设计个人网页(htmlcssjs)——网页设计作业带背景音乐(The way I still Love you)、樱花飘落效果、粒子飘落效果页面美观,样式精美涉及(htmlcssjs),下载后可以根据自己需求进…

8086,8088CPU管脚,奇偶地址体, 时钟信号发生器8284 ,ready信号,reset复位信号。规则字和非规则字

8086/8088均为40条引线,双列直插式封装,某些引线有多重功能,其功能转换有两种情况:一种是分时复用,一种是按组态定义。 用8088微处理器构成系统时,有两种不同的组态: 最小组态:808…

模型效果不好?推荐你8种机器学习调参技巧

大家好,今天给大家一篇关于机器学习调参技巧的文章 超参数调优是机器学习例程中的基本步骤之一。该方法也称为超参数优化,需要搜索超参数的最佳配置以实现最佳性能。 机器学习算法需要用户定义的输入来实现准确性和通用性之间的平衡。这个过程称为超参…

嵌入式开发学习之--RCC(上)

提示:本篇主要介绍一下不同时钟的特性和作用,了解为主。 文章目录前言一、RCC简介二、系统时钟简介2.1HSE 高速外部时钟信号2.2锁相环 PLL2.3系统时钟 SYSCLK2.4AHB 总线时钟 HCLK2.5 APB2 总线时钟 HCLK22.6 APB1 总线时钟 HCLK1三、其他时钟3.1RTC 时钟…

HTTP 请求是什么?

文章目录HTTP请求一,请求行二,请求头三,空行四,请求体五,HTTP请求示例HTTP请求 请求是由客户端向服务器发送的,一般可以分为请求行、请求头、空行和请求体四个部分,如下图所示: 一…

【数据集NO.2】工业检测数据集汇总(缺陷、纹理等检测)

文章目录前言一、东北大学钢材表面缺陷数据集二、天池铝型材表面缺陷数据集三、Severstal 带钢缺陷数据集四、UCI 带钢缺陷数据集五、磁瓦缺陷数据集六、RSDDs铁轨表面缺陷数据集七、印刷电路板(PCB)瑕疵数据集八、坑洼检测数据集九、Kylberg纹理检测十、…

C语言:文件操作(1)

1、什么是文件? 磁盘上的文件是文件。 但是在程序设计中,我们一般谈的文件有两种: 程序文件、数据文件 程序文件: 包括源程序文件(后缀为.c),目标文件(windows环境后缀为.obj),可执行程序(wndows环境后缀为.exe) 数…

初级测试到中级测试就差这几个找bug小技巧

前言 测试的过程就是一个寻找影响产品功能和用户体验bug的过程,测试人员发现的bug类型五花八门。 当你在上班期间,听到不远处传来这样的声音“你会不会提BUG,责任人都指派错了,还能好好提吗?” 如果哪天开发对着你说…

Babel自动生成Attribute文档实现详解

这篇文章主要为大家介绍了Babel自动生成Attribute文档实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助! 1. 前言 利用Babel自动解析源码属性上的注释生成对应Markdown文档,这个场景的应用主要包括在组件库文档对组件…

SpringBoot单元测试

文章目录1、什么是单元测试2、单元测试有哪些好处?3、SpringBoot 单元测试使用3.1 生成单元测试的类3.2 配置单元测试的类并添加SpringBootTest注解3.3 添加单元测试的业务代码3.4 进行测试并查看结果3.5 使用断言3.6 在不修改数据库的前提下,执行单元测…

室内温度控制仿真模型(Simulink+PLC)

本篇博客将会和大家一起一步步解读Simulink自带的仿真模型(Thermal Model of a House),之后再讨论PLC控制系统控制环境温度的一些经验方法。温度控制的大部分控制方法都是采用PID控制,有关PLC的PID控制相关内容可以参看专栏的其它文章,链接如下: 博途PLC 1200/1500PID P…

【LeetCode每日一题:1774. 最接近目标价格的甜点成本~~~递归+深度优先遍历】

题目描述 你打算做甜点,现在需要购买配料。目前共有 n 种冰激凌基料和 m 种配料可供选购。而制作甜点需要遵循以下几条规则: 必须选择 一种 冰激凌基料。 可以添加 一种或多种 配料,也可以不添加任何配料。 每种类型的配料 最多两份 。 给你…

java计算机毕业设计ssm人事考勤管理系统1u133(附源码、数据库)

java计算机毕业设计ssm人事考勤管理系统1u133(附源码、数据库) 项目运行 环境配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff0…

Spread 16.X FOR WPF 中文版 我就喜欢 Spread.NET

Spread 16.X FOR WPF 中文版您可以将 Microsoft Excel 的强大功能嵌入到 WPF 和 Silverlight 应用中,使用丰富的内嵌数据可视化功能展现核心数据和分析结果,按需自定制富有创意的表格模版以及发挥更多便捷高效的功能。Spread WPF-Silverlight 源自备受好…

RIoTBoard开发板系列笔记(十三)—— yocto SDK安装与使用

yocto是一个很强大的嵌入式image 构建工具,借助yocto可以轻松的构建出一个开发板镜像。如果我们想借助yocto开发一些应用层的程序,有以下两种方法可供选择: (1)按照yocto的构建规则添加自己的程序和编译脚步&#xff0…

通话蓝牙耳机什么牌子好?通话工作蓝牙耳机推荐

在一般人的印象中,蓝牙耳机主要是用于听听歌、打打游戏还有煲剧,,而对经常经常外出的商务差旅人士和音乐发烧友来说,蓝牙耳机的通话和续航也是重点关注的,因此,笔者专门整理了一些通话效果好的蓝牙耳机&…