垃圾回收涉及到:阈值触发,并行标记,并发清理。
或者:定期强制回收,释放物理内存。
垃圾回收效率总是Go版本升级的核心问题。
阈值或强制回收
如下图 1:
并行标记
如下图2:
串行或与用户逻辑并发执行
如下图3:
如阈值过大,可能会导致长时间无法触发垃圾回收。因此,每 2 分钟强制检查回收
是非常必要的。每 5 分钟,释放堆中长时间闲置块的物理内存。
此外,在类 UNIX 系统,通过建议操作系统内核解除内存映射的方式释放物理内存,但不回收虚拟内存。再次使用时,因缺页异常,由内核重新配物理内存。