GO GC三色标记和混合写屏障
v1.3 之前使用标记清除法
v1.5 三色标记法
v1.8 混合写屏障
关键词:垃圾回收 自动释放 内存管理 三色标记法 STW(stop the world)
v1.3 标记清除法
1、暂停业务逻辑(stw)
2、根据对象之间的引用关系找出可达对象和不可达对象,并标记需要保留的对象
3、清除未被标记的对象。
4、停止暂停,程序继续(或3 4 互换,缩短STW的范围,提升些许的效率。)
缺点:
STW会让程序暂停,出现程序卡顿,影响了语言的性能(**)
标记需要扫描整个heap,复杂度较大
清除数据会产生heap碎片,造成heap不连续
v1.5 三色标记法
白色、灰色、黑色标记表(灰色标记是中间状态,最后回收所有白色对象)
流程:
1、只要是新创建的对象都默认标记为白色
2、每次GC回收开始,从根节点开始遍历所有对象,把遍历到的白色对象放入灰色标记表中,标记为灰色
3、遍历灰色标记表,将灰色对象