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

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 线程是与用户线程同时运行的

http://www.kler.cn/news/313708.html

相关文章:

  • 2024年9月python二级基本编程题和简单应用题解析(一)
  • Android源码导入Android Studio
  • python怎么打开编辑器
  • 系统架构设计师 大数据架构篇一
  • JVM 执行引擎详解:理论与实践
  • OpenCV calcHist()函数及其用法详解
  • 国标视频流媒体服务GB28181和Ehome等多协议接入的Liveweb方案详解
  • vmware + ubuntu + 初始配置(超级用户权限、vim安装、ssh登陆、共享文件夹、git)
  • 实变函数精解【23】
  • java集合(1)
  • 在 CentOS 中安装 MySQL(无坑版)
  • No operations allowed after statement closed
  • WPF TextBox 控件文本水平垂直居中
  • 写一个自动化记录鼠标/键盘的动作,然后可以重复执行的python程序
  • 华为云分布式缓存服务DCS 8月新特性发布
  • Android-UI设计
  • js 将二进制文件流,下载为excel文件
  • 2024“华为杯”中国研究生数学建模竞赛(E题)深度剖析|数学建模完整过程+详细思路+代码全解析
  • 【Linux取经之路】软件包管理器yum编辑器vim及其配置
  • 进程间关系与进程守护
  • 浅析OceanBase数据库的向量化执行引擎
  • CSS中如何实现鼠标悬停效果?
  • 数据结构:(牛客OR36)链表的回文结构
  • (笔记自用)LeetCode:快乐数
  • mysql时间戳格式化yyyy-mm-dd
  • kubeadm方式安装k8s+基础命令的使用
  • 二层、三层网络基本原理
  • 缓存技巧 · Spring Cache Caffeine 高性能缓存库
  • Github 2024-09-20 Java开源项目日报Top10
  • 【快手】前端校招一面