go 的 gc 机制

2024-03-15  本文已影响0人  五岁小孩

go的gc机制 - Jxy 博客

常见垃圾回收算法

垃圾回收算法 描述 代表语言 优缺点
引用计数 为每个对象维护一个引用计数,记录对象被引用的次数。每当一个对象被引用时,引用计数就会增加。当对象不再被引用时,引用计数就会减少。如果对象的引用计数变为 0,则对象可以被垃圾回收器回收 PythonPHP 优点:实现简单,处理快 。 缺点:无法处理循环引用,两个对象相互引用,计数永远不为0
分代收集 按照对象生命周期长短划分不同的代空间,生命周期长的放入老年代,短的放入新生代,不同代有不同的回收算法和回收频率 Java 优点:性能好。缺点:需要 STW,算法复杂
三色标记法 从根变量开始遍历所有引用的对象,标记引用的对象为不同颜色,<br />被标记为白色的对象进行回收 Golang 优点:解决了引用计数的缺点。缺点:需要 STW,暂时停掉程序运行

以上都需要 STW

Golang 的 Gc 算法

使用 三色标记 + 混合写屏障机制 尽可能减少 STW 的时间

三色标记

如下图:


1.png

混合写屏障机制

在三色标记期间,如果没有STW,并发创建对象,可能存在 垃圾对象或误删对象 的情况:

所以 go 引入了 混合写屏障 机制,满足:

这里需要注意一点,插入屏障仅会在堆内存中生效,不对栈内存空间生效,这是因为go在并发运行时,大部分的操作都发生在栈上,函数调用会非常频繁。数十万goroutine的栈都进行屏障保护自然会有性能问题

所以gc期间,任何在栈上新创建的对象,均为黑色。

完整的 Gc 流程

常见问题

1. gc 多久执行一次,什么时候触发

2. 为什么混合写屏障不保护栈的引用

因为go在并发运行时,大部分的操作都发生在栈上,函数调用会非常频繁。数十万goroutine的栈都进行屏障保护自然会有性能问题

参考资料

源码位置:/go/1.18.3/libexec/src/runtime/mgc.go

详细总结: Golang GC、三色标记、混合写屏障机制 - Code2020 - 博客园 (cnblogs.com)

Golang 垃圾回收机制 有没有详细深入过? (qq.com)

上一篇 下一篇

猜你喜欢

热点阅读