面试官:什么是三色标记


程序员的公众号:源1024获取更多资料,无加密无套路!

最近整理了一波电子书籍资料,包含《Effective Java中文版 第2版》《深入JAVA虚拟机》,《重构改善既有代码设计》,《MySQL高性能-第3版》,《Java并发编程实战》等等
获取方式: 关注公众号并回复 电子书 领取,更多内容持续奉上


三色标记法:垃圾收集器依据可达性分析算法判断对象是否存活时,将遍历GC Roots过程中遇到的对象,按照“是否访问过”这个条件,把对象标记成白色(white)、灰色(gray)、黑色(black)三种颜色。

优点:

可以异步执行,从而可以以中断时间极少的代价或者完全没有中断来进行整个 GC

缺点:

 可能存在标记漏标和标记误标的情况,需要额外的处理来解决这些问题。

 漏标处理方案有:

        CMS:采用的是写屏障 + 增量更新

        G1: 采用的是写屏障 + 原汁快照(SATB)

        ZGC:采用的是读屏障

白色表示对象尚未被扫描,即未被标记为存活对象。

灰色表示对象已经被扫描,但其引用的其他对象尚未被扫描。

黑色表示对象已经被扫描,并且其引用的其他对象也已经被扫描。

 标记过程:

  1. 垃圾收集器在开始垃圾回收时,将所有对象标记为白色。
  2. 然后从根对象开始,递归地遍历对象图,将遇到的对象标记为灰色,并将其引用的对象添加到待扫描队列中。
  3. 接着,垃圾收集器从待扫描队列中取出对象,将其标记为黑色,并将其引用的对象添加到待扫描队列中。这个过程会一直进行,直到待扫描队列为空。
  4. 最后,所有未被标记为黑色的对象即为垃圾对象,可以被回收。

 系列文章索引

MyBatis的插件能在哪些地方进行拦截?

了解MyBatis的缓存机制吗

面试官:谈谈对volatile的理解

Spring中用到了哪些设计模式

面试官:说一下SQL的执行过程

线程池的工作原理


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/160079.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

git提交时会将target也提交

有时候大家在提交git时发现会将编译文件target也提交上去,这种情况有以下几种情况 情况1:项目没有设置.gitignore 情况2:设置了.gitignore但是依然会提交。 第一种:添加.gitignore,并在文件中添加需要忽略的东西。 …

redis分布式锁的学习记录

核心性质 独占性:对于同一把锁,同一时刻只能被一个加锁方独占 健壮性:不能产生死锁。如果有一个因为宕机无法主动解锁,锁也应该被正常加载 对称性:加成和解锁的使用方必须为同一个身份,不允许被非方释放 高…

HCIA-实验命令基础学习:

视频学习: 第一部分:基础学习。 19——子网掩码。 27——防火墙配置: 32——企业级路由器配置: 基础实验完成:(完成以下目录对应的实验,第一部分基础实验就完成。) 方法&#xff…

C //习题 8.13 写一个用矩形法求定积分的通用函数,分别求

C程序设计 (第四版) 谭浩强 习题8.13 习题 8.13 写一个用矩形法求定积分的通用函数,分别求 ∫ 0 1 s i n x d x , ∫ 0 1 c o s x d x , ∫ 0 1 e x d x \int_{0}^{1}sinx\ dx,\ \ \int_{0}^{1}cosx\ …

ILI9225 TFT显示屏16位并口方式驱动

所用屏及资料如后图: ILI9225,176*220,8位或16位并口屏,IM0接GND,电源及背光接3.3v 主控:CH32V307驱动(库文件和STM32基本一样) 一、源码 ILI9225.c #include "ILI9225.h&quo…

设计模式(二)-创建者模式(4)-原型模式

一、为何需要原型模式(Prototype Pattern)? 在软件设计中,我们会遇到到这样的情况:对原对象进行拷贝一个新的副本。想要实现这样的逻辑,有一种笨方法就是对原对象里的所有变量进行逐一赋值。但是这样的做法会导致代码…

【SpringCloud】认识微服务、服务拆分以及远程调用

SpringCloud 1.认识微服务 1.1单体架构 单体架构:将业务的所有功能集中在一个项目中开发,打成一个包部署 单体架构的优缺点: **优点:**架构简单,部署成本低 **缺点:**耦合度高(维护困难&…

【C++】郭老二博文之:C++目录

1、POCO 【POCO】POCO学习总结(一)–下载与编译 【POCO】POCO学习总结(二)——配置选择 【POCO】POCO学习总结(三)——交叉编译 2、C11 2.1 STL算法 【C】C11 STL算法(一):非修改序列操作&a…

笔记59:序列到序列学习Seq2seq

本地笔记地址:D:\work_file\(4)DeepLearning_Learning\03_个人笔记\3.循环神经网络\第9章:动手学深度学习~现代循环神经网络 a a a a a a a a a a a a a a a

C++ Day04 this指针,友元函数,重载

this指针 概念 谁调用 this 所在的函数 ,this 就存储谁的地址 特点 1, 在当前类的非静态成员函数中调用本类非静态成员时 , 默认有 this 关键字 2, 静态成员函数 , 没有 this 指针。 示例 #include <iostream> #include <cstring> using namespace std; class S…

前后端分离项目跨域请求的问题与解决办法

目录 一、为什么会存在跨域请求&#xff1f; 二、跨域请求的流程&#xff1f; 三、什么情况下会触发CROS机制&#xff1f; 四、如何解决跨域请求导致的问题&#xff1f; 一、为什么会存在跨域请求&#xff1f; 跨域请求是因为浏览器的同源策略引起的。同源策略是浏览器的一种…

算法刷题-动态规划2

算法刷题-动态规划2 珠宝的最高价值下降路径最小和 珠宝的最高价值 题目 大佬思路 多开一行使得代码更加的简洁 移动到右侧和下侧 dp[ i ][ j ]有两种情况&#xff1a; 第一种是从上面来的礼物最大价值&#xff1a;dp[ i ][ j ] dp[ i - 1 ][ j ] g[ i ][ j ] 第二种是从左…

10.10-11 科研记录 一些多模态工作的相关思考

论文出发点很简单&#xff0c;第一&#xff0c;就是想要去除文本的冗余数据&#xff0c;有多篇文章也提到了&#xff0c;冗余文本影响对下游任务的性能&#xff0c;大量无关的文本输入到大模型也会影响大模型的性能&#xff0c;本质也很好理解&#xff0c;就是尽可能去除与任务…

握住音乐的法宝 - 简谱

简谱是音乐学习中至关重要的记谱法。除了简谱&#xff0c;还有吉他和钢琴的五线谱&#xff0c;以及我最喜欢的古琴减字谱等其他记谱方式。如果你对音乐感兴趣&#xff0c;一起学习吧&#xff0c;我不允许你是一个文盲。 一、调拍号 “1C 4/4”即为调拍号&#xff0c;调拍号分…

opencv-直方图均衡化

直方图均衡化是一种用于增强图像对比度的图像处理技术。它通过调整图像的灰度级别分布&#xff0c;使得图像中各个灰度级别的像素分布更均匀&#xff0c;从而提高图像的对比度。 在OpenCV中&#xff0c;你可以使用cv2.equalizeHist()函数来进行直方图均衡化。 以下是一个简单…

opencv-2D直方图

cv2.calcHist() 是 OpenCV 中用于计算直方图的函数。它可以计算一维或多维直方图&#xff0c;用于分析图像中像素值的分布。 基本的语法如下&#xff1a; hist cv2.calcHist(images, channels, mask, histSize, ranges[, hist[, accumulate]])参数说明&#xff1a; images:…

[点云分割] 条件欧氏聚类分割

介绍 条件欧氏聚类分割是一种基于欧氏距离和条件限制的点云分割方法。它通过计算点云中点与点之间的欧氏距离&#xff0c;并结合一定的条件限制来将点云分割成不同的区域或聚类。 在条件欧氏聚类分割中&#xff0c;通常会定义以下两个条件来判断两个点是否属于同一个聚类&…

Java继承中的属性名相同但是类型不同的情况

如果子类出现一个属性与父类的属性名一样,那么父类的属性将会被隐藏(java官方文档) 在继承当中,子类继承父类的属性和继承方法的方式上有所差别: 父类属性不可被重写,只会被调用,父类方法可以被重写,也可以被调用 当子类中存在和父类同名属性,父类属性会隐藏起来,在多态的情…

利用Python进行数据分析【送书第六期:文末送书】

&#x1f468;‍&#x1f393;博主简介 &#x1f3c5;云计算领域优质创作者   &#x1f3c5;华为云开发者社区专家博主   &#x1f3c5;阿里云开发者社区专家博主 &#x1f48a;交流社区&#xff1a;运维交流社区 欢迎大家的加入&#xff01; &#x1f40b; 希望大家多多支…