iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >GC垃圾回收的三色标记是什么
  • 743
分享到

GC垃圾回收的三色标记是什么

2023-06-25 13:06:34 743人浏览 八月长安
摘要

这篇文章主要介绍“GC垃圾回收的三色标记是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“GC垃圾回收的三色标记是什么”文章能帮助大家解决问题。GCGC全称Garbage Collection目前

这篇文章主要介绍“GC垃圾回收的三色标记是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“GC垃圾回收的三色标记是什么”文章能帮助大家解决问题。

GC

GC全称Garbage Collection

目前主流的垃圾回收算法有两类,分别是追踪式垃圾回收算法(Tracing garbage collection)和引用计数法( Reference counting )。
而三色标记法是属于追踪式垃圾回收算法的一种。

追踪式算法的核心思想是判断一个对象是否可达,因为一旦这个对象不可达就可以立刻被 GC 回收了。

如何判断一个对象是否可达

分为两步:

  • 第一步找出所有的全局变量和当前函数栈里的变量,标记为可达。

  • 第二步,从已经标记的数据开始,进一步标记它们可访问的变量,周而复始,这一过程也叫传递闭包

Go推出三色标记法之前,go所使用的gc算法叫Mark-And-Sweep(标记清扫)

这个算法就是严格按照追踪式算法的思路来实现的。

  • 先设置一个标志位来记录对象是否被使用,最开始所有的标记位都是 0。

  • 如果发现对象是可达的就会置为1,一步步下去就会呈现一个类似树状的结果。

  • 等标记的步骤完成后,会将没有被标记的对象统一清理,再次把所有的标记位设置成 0, 以便下次进行清理。

这个算法最大的问题是 GC 执行期间需要把整个程序完全暂停,不能异步进行GC操作。因为在不同阶段标记清扫法的标志位 0 和 1 有不同的含义,那么新增的对象无论标记为什么都有可能意外删除这个对象。对实时性要求高的系统来说,这种需要长时间挂起的标记清扫法是不可接受的。所以就需要一个算法来解决 GC 运行时程序长时间挂起的问题,那就三色标记法。

三色标记法

三色标记法是传统 Mark-Sweep 的一个改进,它是一个并发的 GC 算法。on-the-fly

原理如下

整个进程空间里申请每个对象占据的内存可以视为一个图, 初始状态下每个内存对象都是白色标记。

stop the world,将扫描任务作为多个并发的goroutine立即入队给调度器,进而被CPU处理,第一轮先扫描所有可达的内存对象,标记为灰色放入队列

第二轮可以恢复start the world,将第一步队列中的对象引用的对象置为灰色加入队列,一个对象引用的所有对象都置灰并加入队列后,这个对象才能置为黑色并从队列之中取出。循环往复,最后队列为空时,整个图剩下的白色内存空间即不可到达的对象,即没有被引用的对象;

第三轮再次stop the world,将第二轮过程中新增对象申请的内存进行标记(灰色),这里使用了writebarrier(写屏障)去记录这些内存的身份;

这个算法可以实现 on-the-fly,也就是在程序执行的同时进行收集,并不需要暂停整个程序。

简化步骤如下:

GC垃圾回收的三色标记是什么

首先创建三个集合:白、灰、黑。

GC垃圾回收的三色标记是什么

将所有对象放入白色集合中。

GC垃圾回收的三色标记是什么

然后从根节点开始遍历所有对象(注意这里并不递归遍历),把遍历到的对象从白色集合放入灰色集合。

因为root set 指向了A、F,所以从根结点开始遍历的是A、F,所以是把A、F放到灰色集合中。

GC垃圾回收的三色标记是什么

之后遍历灰色集合,将灰色对象引用的对象从白色集合放入灰色集合,之后将此灰色对象放入黑色集合
我们可以发现这个A指向了B,C,D所以也就是把BCD放到灰色中,把A放到黑色中,而F没有指任何的对象,所以直接放到黑色中。

GC垃圾回收的三色标记是什么

重复 4 直到灰色中无任何对象

因为D指向了A所以D也放到了黑色中,而B和C能放到黑色集合中的道理和F一样,已经没有了可指向的对象了。

GC垃圾回收的三色标记是什么

通过write-barrier检测对象有无变化,重复以上操作

由于这个EGH并没有和RootSet有直接或是间接的关系,所以就会被清除。

GC垃圾回收的三色标记是什么

收集所有白色对象(垃圾)

GC垃圾回收的三色标记是什么

所以我们可以看出这里的情况,只要是和root set根集合直接相关的对象或是间接相关的对象都不会被清楚。只有不相关的才会被回收。

关于“GC垃圾回收的三色标记是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: GC垃圾回收的三色标记是什么

本文链接: https://www.lsjlt.com/news/305251.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • GC垃圾回收的三色标记是什么
    这篇文章主要介绍“GC垃圾回收的三色标记是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“GC垃圾回收的三色标记是什么”文章能帮助大家解决问题。GCGC全称Garbage Collection目前...
    99+
    2023-06-25
  • Go语言七篇入门教程七GC垃圾回收三色标记
    目录GC如何判断一个对象是否可达 三色标记法原理如下如何学习GoGC GC全称Garbage Collection 目前主流的垃圾回收算法有两类,分别是追踪式垃圾回收算法(Traci...
    99+
    2024-04-02
  • jvm垃圾回收GC调优基础原理是什么
    这篇文章主要介绍了jvm垃圾回收GC调优基础原理是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇jvm垃圾回收GC调优基础原理是什么文章都会有所收获,下面我们一起来看看吧。说明:Capacity: 性能,能...
    99+
    2023-06-29
  • .Net的GC垃圾回收原理及实现
    一、先了解下必备的知识前提 内存中的托管与非托管,可简单理解为: 托管:可借助GC从内存中释放的数据对象(以下要描述的内容点) 非托管:必须手工借助Dispose释放资源(实现自ID...
    99+
    2024-04-02
  • JVM垃圾回收器是什么
    这篇文章主要讲解了“JVM垃圾回收器是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JVM垃圾回收器是什么”吧!并发与并行并行(Parallel):并行描述的是多条垃圾收集器线程之间的关...
    99+
    2023-07-02
  • python垃圾回收机制是什么
    Python的垃圾回收机制是自动化的,它使用了引用计数和循环垃圾收集两种方法。1. 引用计数:Python中的每个对象都有一个引用计...
    99+
    2023-08-14
    python
  • go垃圾回收机制是什么
    go语言中的垃圾回收机制是指自动管理内存分配和释放的机制。在Go语言中,开发者不需要手动去分配和释放内存,而是由垃圾回收机制自动进行...
    99+
    2023-10-25
    go
  • jvm回收垃圾的机制是什么
    JVM(Java虚拟机)使用自动垃圾回收(Garbage Collection)机制来管理和回收不再使用的对象的内存。以下是JVM垃...
    99+
    2023-08-30
    jvm
  • Java垃圾回收机制是什么
    这篇文章主要介绍“Java垃圾回收机制是什么”,在日常操作中,相信很多人在Java垃圾回收机制是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java垃圾回收机制是什么”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-06-17
  • PHP垃圾回收机制是什么
    本篇内容主要讲解“PHP垃圾回收机制是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PHP垃圾回收机制是什么”吧!PHP的垃圾回收机制垃圾回收机制是一种动态存储分配的方案。它会自动释放程序不...
    99+
    2023-06-20
  • 深入解析标记清理和垃圾回收
    标记清理 标记清理是一个由垃圾回收器进行的后台进程,它识别和标记出不再被使用的对象。该过程包括以下步骤: 根扫描:垃圾回收器从程序的根对象(如全局变量和栈帧)开始,遍历对象图。 标记:对于遇到的每个对象,垃圾回收器都会标记它,表示它已被...
    99+
    2024-04-02
  • java性能调优System的gc垃圾回收方法
    目录一、什么是System.gc()?二、谁可以调用System.gc()?三、调用System.gc()有什么弊端?四、哪些场景适合显式调用System.gc()?五、如何检测您的...
    99+
    2024-04-02
  • Kubernetes中的垃圾回收方法是什么
    本篇内容介绍了“Kubernetes中的垃圾回收方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!考...
    99+
    2024-04-02
  • Node.js中的垃圾回收机制是什么
    这篇“Node.js中的垃圾回收机制是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Node.js中的垃圾回收机制是什么...
    99+
    2023-07-04
  • jvm垃圾回收机制指的是什么
    这篇文章主要介绍“jvm垃圾回收机制指的是什么”,在日常操作中,相信很多人在jvm垃圾回收机制指的是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”jvm垃圾回收机制指的是什么”的疑惑有所帮助!接下来,请跟...
    99+
    2023-07-05
  • php7中垃圾回收机制是什么
    小编给大家分享一下php7中垃圾回收机制是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!php有什么用php是一个嵌套的缩写名称,是英文超级文本预处理语言,它...
    99+
    2023-06-08
  • Python中的垃圾回收机制是什么
    本篇文章给大家分享的是有关Python中的垃圾回收机制是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。GC作为现代编程语言的自动内存管理机制,专注于两件事:1. 找到内存中...
    99+
    2023-06-17
  • PHP中的垃圾回收机制是什么
    这篇文章主要讲解了“PHP中的垃圾回收机制是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP中的垃圾回收机制是什么”吧!相信只要入门学习过一点开发的同学都知道,不管任何编程语言,一个...
    99+
    2023-06-20
  • go:垃圾回收GC触发条件的示例分析
    这篇文章将为大家详细讲解有关go:垃圾回收GC触发条件的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。什么是gogo是golang的简称,golang 是Google开发的一种静态强类型、编译型、...
    99+
    2023-06-14
  • jvm垃圾回收机制的原理是什么
    JVM(Java虚拟机)的垃圾回收机制是自动管理内存的一种机制,它通过识别和释放不再被程序使用的对象,以防止内存泄漏和内存溢出等问题...
    99+
    2023-09-25
    jvm
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作