当前位置: 首页 > news >正文

JVM(HotSpot):GC之垃圾回收阶段

文章目录

  • 前言
  • 一、标记清除算法(Mark Sweep)
  • 二、标记整理算法(Mark Compact)
  • 三、复制算法(Copy)

前言

标记出垃圾对象之后,就要进行清理。
那么,如何清理?

这里也有相应的算法。
主要有三种。

一、标记清除算法(Mark Sweep)

在这里插入图片描述
原理说明:如上图,在JVM内存空间中,根据可达性分析算法,标记出没有被引用的对象为垃圾对象,等待GC回收。那么,清除阶段,直接记录出垃圾对象的起始坐标和结束坐标。那么,这段坐标内,即为可用内存。所以,清除速度快

缺点:造成空间碎片,使得较大对象无法存入,浪费了碎片空间。

二、标记整理算法(Mark Compact)

在这里插入图片描述
原理说明:这个算法,其实是在标记清除算法的基础上的一个优化。标记清除算法存在的缺点就是,空间碎片问题,所以,这里在清除垃圾对象的同时,进行存活对象的移动,把对象存放到一个连续的空间中,从而,是可用空间保持连续。解决了空间碎片问题。

缺点:因为,存活对象的移动,一定会涉及到复制工作,并且,移动后的对象,内存地址也会发生改变。从而导致,原始引用需要修改对象地址。从而造成效率低下。

三、复制算法(Copy)

在这里插入图片描述在这里插入图片描述在这里插入图片描述
原理说明:内存分为FROMTO两块区域,GC发生时,会将FROM中的存活对象复制到TO区域,再将FROM中的垃圾对象清除掉。然后,将原来的TO区域标记为FROM区域,原来的FROM区域标记为TO区域。没有内存碎片。

缺点:空间利用率较低。

http://www.lryc.cn/news/464103.html

相关文章:

  • Go 项目如何集成类似mybatisPlus插件呢?GORM走起!!
  • 《深度学习》Dlib库 CNN卷积神经网络 人脸识别
  • 滚雪球学Redis[7.1讲]:Redis实战案例
  • WordPress外部图片本地化插件
  • Linux基础-shell的简单实现
  • Tomcat日志文件详解及catalina.out日志清理方法
  • react 中的hooks中的useState
  • STM32学习笔记---DMA
  • Cesium 实战 - 自定义纹理材质 - 立体墙(旋转材质)
  • 进程间关系与守护进程
  • 金山翻译接口逆向
  • unified-runtime编译与验证
  • 【Python】最详细--基础语法
  • 二叉树基础:什么样的二叉树适合用数组来存储?
  • iTOP-RK3568开发板独立NPU通过算法加特应用到以下的场景
  • Java基于SpringBoot微信小程序的跳蚤市场系统设计与实现(lw+数据库+讲解等)
  • 【分布式微服务云原生】《Redis 的高效之道:线程模型、IO 模型与 Reactor 模型全解析》
  • 科研类型PPT的制作技巧
  • rom定制系列------小米6x_MIUI14_安卓13刷机包修改写入以及功能定制 界面预览
  • 线性代数基础02
  • 「4.4」祖孙询问
  • Datawhale 组队学习 文生图 Prompt攻防 task03随笔
  • 游戏投屏软件有哪些?分享这10款比较好用的!
  • [Unity Demo]从零开始制作空洞骑士Hollow Knight第十六集(下篇):制作小BOSS龙牙哥
  • 顺序表算法题【不一样的解法!】
  • VuePress的基本常识
  • 深入解析Vue2与Vue3的区别与Vue3的提升
  • 认识python数据分析
  • 以太网交换安全:MAC地址漂移与检测(实验:二层环路+网络攻击)
  • NeRF三维重建—神经辐射场Neural Radiance Field(二)体渲染相关