GO 语言GC

目录

写屏障

 读屏障

GO语言GC准备

堆内存结构:

 GC内存分配:

GC触发:

P的作用:


写屏障

实现强弱三色不式,为了避免误删,则实现写屏障.

写屏障是在写操作中插入指令,目的是把数据对象的修改通知到GC

GO语言支持两种写屏障

GO 语言GC_第1张图片

 读屏障

非移动垃圾回收(例如 三色)天然不需要读屏障.像复制式垃圾回收器则需要: 例如这个问题

GO 语言GC_第2张图片

 


GO语言GC准备

1,为每个P准备mark work 协程.等待标记阶段.

标记工作从扫描BSS段,数据段,以及协程栈上的root节点追踪到root.从元数据获root ,堆也有元数据

GO 语言GC_第3张图片

 确定是存活指针还要确定是否指向堆内存:,如果指向堆内存,则把他们加入到GC中进一步扫描.

堆内存结构:

GO 语言GC_第4张图片

 GO 语言GC_第5张图片

 知道哪些数据一开始要标记灰色后.我们将其加入到工作队列.

GO 语言GC_第6张图片

 GC默认CPU使用率25%.

GO 语言GC_第7张图片

 GC内存分配:

1.若协程需要申请内存,而GC尚未完成,则协程需要当任部分GC工作,借贷尝还机制.

2.每次内存分配都会检查是否需要辅助标记.到GC清扫阶段,内存分配就会促发辅助清扫.例如,分配一个span,若这个span尚未清扫,则需要清扫完再使用.辅助标记和辅助清扫可以避免并发垃圾回收中内存过大的分配压力导致来不及清扫

GC触发:

1 手动

2,分配内存

3,GPM的监控线程检测上次GC意见已经过了一段时间.


P的作用:

1,分配内存

2,避免M从全局获取G要加锁

你可能感兴趣的:(Go语言,golang,开发语言,后端)