Golang各版本的GC详解

go v1.3的标记清除法

  1. 清除的第一步:stw
  2. 将可达对象标记
  3. 删除未被标记对象

go v1.5三色标记法

  1. 从根节点出发,将下一个节点遍历为灰色,放入灰色集合中
  2. 遍历灰色节点集合,把灰色能到达的节点标记为灰色,把自身标记为黑色,放入黑色集合中
  3. 重复上述流程 ...,把最终剩余的白色对象进行清楚

会出现对象丢失问题,例子如下:

对象2 引用 对象3,对象4 引用 对象3 ------> 对象4 引用 3

可以在进行gc期间,启动stw,这样就不会出现问题,但是stw有明显的资源浪费。可以通过强弱三色不变式的思路来解决对象丢失问题:

强三色不变式:黑色对象不能引用白色对象

弱三色不变式:黑色对象可以引用白色对象,但是白色对象存在上游对象

对于强三色不变式的实现,通过插入写屏障机制实现(只在栈空间启用):在A对象引用B对象时候,若B对象为白色,就把它标记为灰色。

注意:栈空间不启用插入写屏障,还会造成对象丢失问题,因为栈空间一个黑色对象新创建了一个白色对象时候,若没有插入写屏障,会造成白色对象丢失,

所以在最终准备回收白色前,启动stw,重新扫描一次栈空间,重新标记,避免对象丢失

对于弱三色不变式的实现,通过删除写屏障实现:在对象A取消对对象B的引用时候,会把B对象标记为灰色。

上面是通过插入写屏障和删除写屏障来避免对象丢失问题。会有两个问题:

插入写屏障的不足:准备回收白色对象垃圾时候,需要stw

删除写屏障的不足:回收精度低,删除一个对象需要下一轮才能删除

于是go语言就引入了混合写屏障。

go v1.8 三色标记法 + 混合写屏障

  1. GC开始将栈上的对象全部扫描并标记为黑色
  2. GC期间,任何在栈上创建的新对象,均为黑色
  3. 被删除的对象标记为灰色
  4. 被添加的对象标记为灰色

前两步避免了事后的栈空间的stw。后两步结合了删除写屏障和插入写屏障。

相关推荐
方博士AI机器人6 分钟前
算法与数据结构 - 常用图算法总结
算法
code monkey.8 分钟前
【探寻C++之旅】第十三章:红黑树
开发语言·数据结构·c++
柯南二号9 分钟前
Go使用Gin写一个对MySQL的增删改查服务
mysql·golang·gin
一匹电信狗28 分钟前
【C++】手搓一个STL风格的string容器
c语言·数据结构·c++·算法·leetcode·stl·visual studio
杜子腾dd37 分钟前
14.Excel:排序和筛选
数据结构
Susea&1 小时前
趣味编程:答案之书
c语言·开发语言·c++·算法·技术美术
机器视觉知识推荐、就业指导1 小时前
Qt/C++面试【速通笔记七】—Qt中为什么new QWidget不需要手动调用delete?
c++·qt·面试
李匠20241 小时前
C++GO语言微服务和服务发现
开发语言·c++·golang·服务发现
heart000_12 小时前
2025蓝桥杯十六届C++ B组题解与代码分析
c++·算法·蓝桥杯