大厂面试题-JVM中的三色标记法是什么?

目录

问题分析

问题答案


题分析

三色标记法是Java虚拟机(JVM)中垃圾回收算法的一种,主要用来标记内存中存活和需要回收的对象。

它的好处是,可以让JVM不发生或仅短时间发生STW(Stop The World),从而达到清除JVM内存垃圾的目的,JVM中的「CMS、G1垃圾回收器」都用到了三色标记法。

下面来看一下这个问题的解答。

题答案

在三色标记法中,Java虚拟机将内存中的对象分为三个颜色:

  1. 白色:表示还没有被垃圾回收器扫描的对象;

  2. 黑色:表示已经被垃圾回收器扫描过,且对象及其引用的其他对象都是存活的;

  3. 灰色:表示已经被垃圾回收器扫描过,但对象引用的其他对象尚未被扫描。

在GC开始时(如图),先将所有对象都标记为白色,然后从根对象开始遍历内存中的对象,接着把直接引用的对象标记为灰色。

再判断灰色集合中的对象是否存在子引用,不存在咋放入黑色集合,如果存在,就把子引用对象放入到灰色集合。

按照这样一个步骤不断推导,直到灰色集合中所有的对象变黑后,本轮标记完成。最后,还处于白色标记的对象就是不可达对象,可以直接被回收。

相关推荐
江湖十年22 分钟前
Go 并发控制:sync.Pool 详解
后端·面试·go
rainbow72424427 分钟前
AI人才简历评估选型:技术面试、代码评审与项目复盘的综合运用方案
人工智能·面试·职场和发展
张张123y34 分钟前
RAG从0到1学习:技术架构、项目实践与面试指南
人工智能·python·学习·面试·架构·langchain·transformer
努力学算法的蒟蒻2 小时前
day115(3.17)——leetcode面试经典150
面试·职场和发展
Baihai_IDP3 小时前
OpenClaw 架构详解 · 第一部分:控制平面、会话管理与事件循环
人工智能·面试·llm
2301_793804694 小时前
更优雅的测试:Pytest框架入门
jvm·数据库·python
ole ' ola4 小时前
lambda表达式
java·前端·jvm
2301_815482935 小时前
用Python实现自动化的Web测试(Selenium)
jvm·数据库·python
小涛不学习6 小时前
HTTP 和 HTTPS 详解(原理 + 区别 + 面试重点)
http·面试·https
Moment6 小时前
MiniMax 发布 M2.7,Agent 开始走向自我进化
前端·后端·面试