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

目录

问题分析

问题答案


题分析

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

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

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

题答案

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

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

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

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

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

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

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

相关推荐
蓝色的杯子13 分钟前
Python面试30分钟突击掌握-LeetCode1-Array
开发语言·python·面试
不爱吃炸鸡柳24 分钟前
6道经典算法题详解:从排序到链表,覆盖面试高频考点
算法·链表·面试
何陋轩29 分钟前
AI时代,程序员何去何从?别慌,看完这篇你就明白了
后端·面试
keqistarry29 分钟前
java-python快速转语言
面试
Wect1 小时前
JS手撕:函数进阶 & 设计模式解析
前端·javascript·面试
前端摸鱼匠1 小时前
【AI大模型春招面试题18】 L1、L2正则化、Dropout、早停(Early Stopping)的原理与适用场景?
人工智能·ai·语言模型·面试·大模型
Qinana1 小时前
前端正则表达式全解:从基础语法到实战应用
前端·javascript·面试
im_AMBER1 小时前
万字长文:手撕JS深浅拷贝完全指南
前端·javascript·面试
哈里谢顿1 小时前
ELK 详解:架构、配置与面试重点
面试
有意义2 小时前
深入理解浏览器存储方案:从Cookie到JWT登录认证
前端·面试·浏览器