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

JVM四种垃圾回收算法以及G1垃圾回收器(面试)

JVM 垃圾回收算法

标记清除算法:标记清除算法将垃圾回收分为两个阶段:标记阶段和清除阶段
在标记阶段通过根节点,标记所有从根节点开始的对象。然后,在清除阶段,清除所有未被标记的对象
适用场合存活对象较多的场景下比较高效
缺点:容易产生内存碎片
复制算法:从根节点进行扫描,标记出所有的存活对象,然后将这些存活的对象复制到一块新的内存上,之后将原来的旧内存全部回收
适用场合: 存活对象较少的情况下比较高效
缺点:复制过程需要一块儿空的内存空间,对内存消耗较大。
标记整理算法:是标记清除算法的优化版本
在标记阶段通过根节点(GC Roots),标记所有从根节点开始的对象。但在清除阶段,它会将所有的存活对象压缩到内存的一端再清理边界外所有的空间。避免了内存碎片的产生
分代回收:分代收集算法就是目前虚拟机使用的回收算法,一般情况下将堆区划分为老年代和新生代

垃圾回收器

G1垃圾回收器使用分代回收算法,任何垃圾回收器在进行工作的时候都会出现 STW,Stop the World 停止用户线程程
G1 全称 Garbage-First 通过将堆内存划分为多个 Region 来实现可预测的停顿时间模型。在 G1 当中,新生代和老年代已经不再是物理隔离,而都是被划分一个个 Region 区域
G1 垃圾回收器的整个实现过程分为四个步骤:

  1. 初始标记:标记根节点的直接关联对象。这个阶段会STW;
  2. 并发标记:通过根节点找到存活的对象。这个阶段 GC 线程是与用户线程同时运行的
  3. 最终标记:修正并发标记过程中因用户线程继续运行而导致产生新的引用更新。同样的这里也需要 STW;
  4. 筛选回收:筛选回收这里会对每个 Region 的回收成本进行排序,根据用户期望的停顿时间来制定收回计划。这个阶段 GC 线程是与用户线程同时运行的

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 今日leetCode 242.有效的字母异位词
  • 云服务器部署DB-GPT项目
  • .Net 执行Linux下多行shell命令方法
  • 无线领夹麦克风哪个牌子好,口碑最好的麦克风品牌,领夹麦推荐
  • 什么是数据资源?
  • ImportError: DLL load failed while importing _ssl: 找不到指定的模块的解决方法
  • .NET/C#⾯试题汇总系列:集合、异常、泛型、LINQ、委托、EF!(完整版)
  • 大模型从失败中学习 —— 微调大模型以提升Agent性能
  • 【贪心算法】贪心算法
  • 油耳用什么掏耳朵比较好?可视挖耳勺推荐平价
  • 【linux】 cd命令
  • DMA与AXI DMA ip
  • 【干货分享】Ftrans安全数据交换系统 搭建跨网数据传输通道
  • 工业大模型市场图谱:53个工业大模型全面梳理
  • CSS 笔记 1
  • angular组件开发
  • create-react-app做的留言板
  • Flex布局到底解决了什么问题
  • seaborn 安装成功 + ImportError: DLL load failed: 找不到指定的模块 问题解决
  • Spring技术内幕笔记(2):Spring MVC 与 Web
  • tab.js分享及浏览器兼容性问题汇总
  • UMLCHINA 首席专家潘加宇鼎力推荐
  • Vim Clutch | 面向脚踏板编程……
  • 测试开发系类之接口自动化测试
  • 当SetTimeout遇到了字符串
  • 对话 CTO〡听神策数据 CTO 曹犟描绘数据分析行业的无限可能
  • 搞机器学习要哪些技能
  • 观察者模式实现非直接耦合
  • 实现简单的正则表达式引擎
  • 算法---两个栈实现一个队列
  • 详解NodeJs流之一
  • 用Python写一份独特的元宵节祝福
  • 栈实现走出迷宫(C++)
  • 追踪解析 FutureTask 源码
  • ​一帧图像的Android之旅 :应用的首个绘制请求
  • # Swust 12th acm 邀请赛# [ A ] A+B problem [题解]
  • ###项目技术发展史
  • #鸿蒙生态创新中心#揭幕仪式在深圳湾科技生态园举行
  • #我与Java虚拟机的故事#连载09:面试大厂逃不过的JVM
  • (04)odoo视图操作
  • (1) caustics\
  • (2024.6.23)最新版MAVEN的安装和配置教程(超详细)
  • (ZT)一个美国文科博士的YardLife
  • (附源码)springboot猪场管理系统 毕业设计 160901
  • (九十四)函数和二维数组
  • (每日持续更新)jdk api之FileFilter基础、应用、实战
  • (四)c52学习之旅-流水LED灯
  • (转载)微软数据挖掘算法:Microsoft 时序算法(5)
  • .“空心村”成因分析及解决对策122344
  • .NET Core 网络数据采集 -- 使用AngleSharp做html解析
  • .NET 通过系统影子账户实现权限维持
  • .NET/C# 利用 Walterlv.WeakEvents 高性能地中转一个自定义的弱事件(可让任意 CLR 事件成为弱事件)
  • .NET导入Excel数据
  • .Net下C#针对Excel开发控件汇总(ClosedXML,EPPlus,NPOI)
  • .NET中统一的存储过程调用方法(收藏)