Mark: Mark objects and follow pointers 。标记所有根对象, 和根对象可以到达的所有对象不被回收 。 Mark Termination: Rescan globals/changed stack, finish mark 。重新扫描全局变量,和上一轮改变的stack(写屏障),完成标记工作 。这个过程需要STW 。 Sweep: 按标记结果清扫span目前整个GC流程会进行两次STW(Stop The World), 第一次是Stack scan阶段, 第二次是Mark Termination阶段.
- 第一次STW会准备根对象的扫描, 启动写屏障(Write Barrier)和辅助GC(mutator assist).
- 第二次STW会重新扫描部分根对象, 禁用写屏障(Write Barrier)和辅助GC(mutator assist).
从1.8以后的golang将第一步的stop the world 也取消了,这又是一次优化; 1.9开始, 写屏障的实现使用了Hybrid Write Barrier, 大幅减少了第二次STW的时间.
写屏障
因为go支持并行GC, GC的扫描和go代码可以同时运行, 这样带来的问题是GC扫描的过程中go代码有可能改变了对象的依赖树 。
例如开始扫描时发现根对象A和B, B拥有C的指针 。
- GC先扫描A,A放入黑色
- B把C的指针交给A
- GC再扫描B,B放入黑色
- C在白色,会回收;但是A其实引用了C 。
为了避免这个问题, go在GC的标记阶段会启用写屏障(Write Barrier).
启用了写屏障(Write Barrier)后,在GC第三轮rescan阶段,根据写屏障标记将C放入灰色,防止C丢失 。
参考:
Go 垃圾回收原理
Golang源码探索(三) GC的实现原理
推荐阅读
-
「橘猫」橘猫每天来敲窗,男孩为收养它下血本,半年后却发现是邻居家养的
-
-
-
翡翠|顶级帝王绿翡翠《长城》,价值5亿6千万港元!
-
-
-
中国青年报|热点 | 超100人遇难,有中国公民受伤!我赴黎维和部队已待命救援
-
-
东方网|护航进博 |两栖车驶上浦江滩涂“身怀绝技”的“清道夫”
-
-
秦岚|43岁秦岚与小17岁的王子异上演姐弟恋,真的没年轻演员了吗?
-
windows10|3GB+极度精简+不更新,被誉为最纯净Windows10,老爷机总算有救了
-
#蓝田发布#陕U号牌能自编吗?哪些汽车能选择陕U号牌?权威回应来了~
-
-
#观察者#回到广州,被困伦敦的美国女孩哭诉:我想赶紧回家
-
怎样看汽车的水温表-汽车水温表怎么看-水温表介绍-
-
-
-
『万州微视界』华为真的在欧洲那么受欢迎吗?讲一个真实的故事,出乎你的意料
-
提升幸福的方法积极心理学?如何利用心理学提升幸福感