【JVM】垃圾释放方式:标记-清除、复制算法、标记-整理、分代回收

文章目录

  • 1. 标记-清除
  • 2. 复制算法
  • 4. 标记-整理
  • 4. 分代回收

把标记为垃圾的对象的内存空间进行释放。主要有三种释放方式

1. 标记-清除

把标记为垃圾的对象,直接释放掉(最朴素的做法)

image.png
此时就是把标记为垃圾的对象所对应的内存空间直接释放。但这样的释放会产生“内存碎片”问题

  • 上述释放方式,就可能会产生很多小的,但是离散的空闲内存空间
  • 这样就可能会导致后续申请内存失败
    • 因为内存申请都是一次申请一个连续的空间
    • 申请 1M 内存空间,此时 1M 都是连续的
  • 如果存在很多内存碎片,就可能导致总的空闲空间远远超过 1MB,但是并不存在比 1M 大的连续空间。此时,去申请内存就会失败

类似于,你去吗房子,需要一次性付 30W 首付。你的总存款超过了 30W,但是可能分散在不同的卡上,所以就没法完成上述的支付操作

一般不会使用这个方案,内存碎片问题,比较致命

2. 复制算法

复制算法的核心就是:不直接释放内存,而是把不是垃圾的对象,复制到内存的另一半里面。

  • 然后就把左侧空间整体释放掉image.png|499

确实能规避内存碎片问题,但是也有缺点:

  1. 总的可用内存变少了(买两碗豆浆,喝一碗倒一碗)

  2. 如果每次要复制的对象比较多,此时复制的开销也就很大了。

需要是当这一轮 GC 的过程中,大部分对象都释放,少数对象存活,这个时候适合用复制

4. 标记-整理

类似于顺序表删除中间元素,中间有个“搬运”的过程

image.png|378

  • 若要删除 1,就把 2 往前搬,覆盖掉 1,3 覆盖掉 2… 最后把后面的内存释放

通过这个过程,也可以解决内存碎片问题,并且这个过程也不像复制算法一样,需要浪费过多的内存空间。但是,这里的搬运内存的开销很大

因此,JVM 没有直接使用上述的方案,而是结合上述思想,高出了一个“综合性”方案,取长补短

4. 分代回收

依据不同种类的对象,采取不同的方式

引入概念:对象的年龄

  • JVM 中,有专门的线程负责周期性扫描/释放
  • 一个对象如果被线程扫描了一次,可达了(不是垃圾),年龄就+1(初始年龄相当于是 0)

JVM 中就会跟对象年龄的差异,把整个堆内存分为两个大的部分:新生代(年龄小的对象)/老年代(年龄大的对象)

年龄也是会占内存的,每个对象有一个“对象头”,在对象头里有一个属性来存储年龄

image.png|555

  1. 当我们代码中 new 出一个新的对象,这个对象就是被创建在伊甸区,在伊甸区会有很多对象

    • 一个经验规律:伊甸区中的对象,大部分是活不过第一轮 GC 的(朝生夕死,生命周期非常短)
  2. 第一轮 GC 扫描完成之后,少数在伊甸区中幸存的对象,就会通过复制算法,复制到生存区

    • 后续的 GC 扫描线程还会持续的扫描,不仅要扫描伊甸区,还要扫描生存区的对象
    • 生存区中的大部分对象也会在扫描中被标记为垃圾
    • 少数存活的,就会继续使用复制算法,复制到另一个生存区中
    • 只要这个对象能够在生存区中继续存活,就会被复制算法继续拷贝到另一半的生存区中
    • 每经历一轮 GC,对象的年龄就会+1

每一次拷贝不仅仅只有生存区的对象进行互相拷贝,还有来自伊甸区的对象

  1. 如果这个对象在生存区中, 经过了若干轮 GC 仍然健在,JVM 就会认为,这个对象生命周期大概很长,就会把这个对象从生存区拷贝到老年代

  2. 老年代的对象,当然也要被 GC 扫描,但是扫描频次就会大大降低了

老年代的对象,要寄早寄了。既然没有寄,说明其生命周期应该是很长的,频繁 GC 扫描意义也不大,白白浪费时间。不入放到老年代,降低扫描频率

  1. 对象在老年代寿终正寝,此时 JVM 就会按照标记整理的方式,释放内存

上述过程,也是非常好理解的。这个过程和我们找工作是一模一样的

  • 伊甸区:一个公司收到很多的简历,然后安排笔试。笔试的过程就会使绝大部分的人被刷掉,少数的人能进入到面试环节
  • 生存区:进入面试环节,面试有很多轮,每一轮也会刷掉一批人
  • 老年代:通过了上述层层筛选,拿到 offer,进入公司入职了。
    - 进入公司后也会有绩效考评、末位淘汰,但周期比较长,远远超过笔试和面试

上述分代回收是 JVM GC 中的核心思想。但是 JVM 实际的垃圾回收的实现细节上,还会存在一些变数和优化

垃圾收集器就是具体实际的情况
课件列出了 7 个垃圾收集器,主要掌握 CMS,G1(ZGC)

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Visual Studio C# 处理和修复 WinRiver II 测量项目 MMT 文件错误

Visual Studio C# 处理和修复 WinRiver II 测量项目 MMT 文件错误 前言一、WinRiver II 测量项目 MMT 文件的结构二、WinRiver II 无法打开或操作测量项目 MMT 文件2.1 无法载入船测多线法测量文件2.2 可以载入测验项目 MMT 文件,但 ADCP 后处理软件无法写入信息2.3…

【数学分析笔记】第4章第4节 复合函数求导法则及其应用(2)

4. 微分 4.4 复合函数求导法则及其应用 【例4.4.3】 y e 1 cos ⁡ x ye^{\sqrt{1\cos x}} ye1cosx ​,求 y ′ y y′ 【解】 y ′ e 1 cos ⁡ x ⋅ 1 2 1 cos ⁡ x ⋅ ( − sin ⁡ x ) − sin ⁡ x 2 1 cos ⁡ x e 1 cos ⁡ x ye^{\sqrt{1\cos x}}\cdot\f…

JavaScript 中最快的循环是什么?

无论使用哪种编程语言,循环都是一种内置功能。JavaScript 也不例外,它提供了多种实现循环的方法,偶尔会给开发人员带来困惑:哪一种循环才是最快的? 以下是Javascript中可以实现循环的方法: For Loop While …

Pikachu- Over Permission-垂直越权

以admin 账号登陆,添加一个用户; 把添加用户的这个请求发送到 repeater; 退出admin,使用普通用户pikachu登陆; 只有查看权限; 使用pikachu 用户的认证信息,替换repeater处管理员创建用户请求的…

0基础学前端 day6 -- 搭建github pages静态网址

标题:如何通过 GitHub Pages 创建一个静态网站 GitHub Pages 是 GitHub 提供的一项免费服务,允许用户从 GitHub 仓库中托管静态网站。对于开发者和非开发者来说,这都是一个极其便利的工具,用于创建和发布个人博客、项目文档或作品…

Redis中GEO数据结构实现附近商户搜索

Redis的版本必须是6.2以上 在测试类中将数据导入Redis Testvoid loadShopData(){//1.查询店铺信息List<Shop> list shopService.list();//2.把店铺分组&#xff0c;按照typeId分组&#xff0c;typeId一致的放到一个集合Map<Long, List<Shop>> map list.s…

在vscode在使用idea编辑器的快捷键

在vscode在使用idea编辑器的快捷键 在vscode扩展在搜索idea key结果如下&#xff1a; 选择IntelliJ IDEA Keybindings安装&#xff08;注意作者是Keisuke Kato&#xff09;&#xff0c;安装后就可以在vscode编辑器中使用idea编辑器的快捷键。

五子棋双人对战项目(2)——登录模块

目录 一、数据库模块 1、创建数据库 2、使用MyBatis连接并操作数据库 编写后端数据库代码 二、约定前后端交互接口 三、后端代码编写 文件路径如下&#xff1a; UserAPI&#xff1a; UserMapper&#xff1a; 四、前端代码 登录页面 login.html&#xff1a; 注册页面…

ZenStack全栈开发工具(一)快速使用指南

简介 ZenStack是一个TypeScript工具&#xff0c;通过灵活的授权和自动生成的类型安全的 API/钩子来增强 Prisma ORM&#xff0c;从而简化全栈开发 数据库-》应用接口 数据库-》前端 参考官方网站&#xff1a;https://zenstack.dev/ 如果我们想做一个全栈开发的web应用程序&am…

记一次教学版内网渗透流程

信息收集 如果觉得文章写的不错可以共同交流 http://aertyxqdp1.target.yijinglab.com/dirsearch dirsearch -u "http://aertyxqdp1.target.yijinglab.com/"发现 http://aertyxqdp1.target.yijinglab.com/joomla/http://aertyxqdp1.target.yijinglab.com/phpMyA…

算法笔记(九)——栈

文章目录 删除字符串中的所有相邻重复项比较含退格的字符串基本计算机II字符串解码验证栈序列 栈是一种先进后出的数据结构&#xff0c;其操作主要有 进栈、压栈&#xff08;Push&#xff09; 出栈&#xff08;Pop&#xff09; 常见的使用栈的算法题 中缀转后缀逆波兰表达式求…

大学生就业市场:Spring Boot招聘系统的设计与实现

4系统概要设计 4.1概述 本系统采用B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式&#xff0c;是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在任何时间、任何地点使用。系统工作原理图如图4-1所示&#xff1a; 图4-1系统工作原理…

MySQL中NULL值是否会影响索引的使用

MySQL中NULL值是否会影响索引的使用 为何写这一篇文章 &#x1f42d;&#x1f42d;在面试的时候被问到NULL值是否会走索引的时候&#xff0c;感到有点不理解&#xff0c;于是事后就有了这篇文章 问题&#xff1a; 为name建立索引&#xff0c;name可以为空select * from user …

OpenHarmony标准系统上实现对rk系列芯片NPU的支持(npu使用)

在上篇文章中&#xff0c;我们学习了移植rk的npu驱动到OpenHarmony提供的内核。本文我们来学习如何在OpenHarmony标准系统rk系列芯片如何使用npu OpenHarmony RK系列芯片运行npu测试用例 在移植npu驱动到OpenHarmony之后&#xff0c;来运行npu样例进行简单测试 1.O 测试准备…

ModuleNotFoundError: No module named ‘package‘

报错&#xff1a; Traceback (most recent call last): File “”, line 198, in run_module_as_main File “”, line 88, in run_code File "D:\python\helloworld.venv\Scripts\pip.exe_main.py", line 4, in File "D:\python\helloworld.venv\Lib\site-pac…

昇思学习打卡营第32天|基于ResNet50的中药炮制饮片质量判断模型

背景介绍 中药炮制是根据中医药理论&#xff0c;依照临床用药需求&#xff0c;通过调剂和制剂要求&#xff0c;将中药材制备成中药饮片的过程。老百姓日常使用的中药饮片&#xff0c;是中药炮制技术的成果。中药炮制过程中&#xff0c;尤其是涉及到水火处理时&#xff0c;必须注…

电器自动化入门08:隔离变压器、行程开关介绍及选型

视频链接&#xff1a;3.4 电工知识&#xff1a;三相交流异步电动机自动往返行程控制及控制变压器选型_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1PJ41117PW?p8&vd_sourceb5775c3a4ea16a5306db9c7c1c1486b5 1.隔离&#xff08;控制&#xff09;变压器 2.行程开…

【AI】AIOT简介

随着技术的快速发展&#xff0c;人工智能AI和物联网IoT已经成为当今最热门的技术领域。AIOT是人工智能和物联网的结合&#xff0c;使物联网设备更加智能化&#xff0c;能够进行自主决策和学习的技术。 通过物联网产生、收集来自不同维度的、海量的数据存储于云端、边缘端&#…

828华为云征文|部署个人文档管理系统 Docspell

828华为云征文&#xff5c;部署个人文档管理系统 Docspell 一、Flexus云服务器X实例介绍二、Flexus云服务器X实例配置2.1 重置密码2.2 服务器连接2.3 安全组配置2.4 Docker 环境搭建 三、Flexus云服务器X实例部署 Docspell3.1 Docspell 介绍3.2 Docspell 部署3.3 Docspell 使用…

深度学习基础—目标定位与特征点检测

1.目标定位 &#xff08;1&#xff09;定义 目标定位就是在图片中&#xff0c;定位对象的位置&#xff0c;对于对象的位置可以用框圈住显示。如下图所示&#xff1a; 假设正在进行图片分类工作&#xff0c;那么这个汽车图片很有可能被分类为汽车类别。对于目标定位&#xff0c;…