0

0

Go 语言垃圾回收机制详解:谁在执行 GC?如何工作?

花韻仙語

花韻仙語

发布时间:2026-01-23 23:02:21

|

684人浏览过

|

来源于php中文网

原创

Go 语言垃圾回收机制详解:谁在执行 GC?如何工作?

go 的垃圾回收由运行时(runtime)内置的原生代码实现,采用并发标记清除算法,不依赖虚拟机;gc 过程中仅短暂 stw,与 java 的分代 gc 有本质区别。

Go 是一门编译型语言,源码直接编译为机器码,生成静态链接的原生二进制可执行文件,不依赖虚拟机(如 JVM)或解释器。但这并不意味着它没有运行时系统——恰恰相反,Go 拥有一个高度集成、用 C 和汇编编写的 Go Runtime,它内置于每个 Go 程序中,负责调度 goroutine、内存管理、增长、网络轮询以及垃圾回收(GC)等核心功能。

那么,谁在执行垃圾回收?
答案是:Go Runtime 中的原生(native)C/汇编代码,运行在操作系统线程(OS threads)上。它不是由 Go 语言编写的 goroutine 实现,也不是用户态抽象层的一部分;而是深度嵌入 runtime 的底层系统组件。从 Go 1.1 开始,GC 已支持并行(parallel)与并发(concurrent)模式,并在 Go 1.5 后全面转向三色标记 + 并发清除的低延迟设计。这意味着:

  • 标记阶段大部分与用户代码并发执行(mutator concurrent),仅需极短的 STW(Stop-The-World)暂停(通常 < 100 微秒),用于根对象扫描(如全局变量、goroutine 栈);
  • 清除阶段也逐步并发化,避免内存瞬时抖动;
  • GC 工作由 runtime 自动启动(基于堆增长率触发),由多个 OS 线程协同完成,而非单一线程或某个“隐藏 goroutine”。

例如,可通过以下方式观察 GC 行为:

GODEBUG=gctrace=1 ./myapp

输出类似:

gc 1 @0.021s 0%: 0.010+1.2+0.019 ms clock, 0.080+0.24/0.70/0.36+0.15 ms cpu, 4->4->2 MB, 5 MB goal, 8 P

其中 0.010+1.2+0.019 分别表示 STW 标记开始时间、并发标记时间、STW 标记结束时间(单位:毫秒)。

LLaMA
LLaMA

Meta公司发布的下一代开源大型语言模型

下载

⚠️ 注意事项:

  • GC 不可被手动强制触发(runtime.GC() 仅建议运行,不保证立即执行,且会引发一次完整 STW,应避免在性能敏感路径调用);
  • Go 的 GC 是统一堆模型(unified heap),无新生代/老年代划分,也不使用压缩(compaction)或复制算法,因此不会发生内存碎片整理,但对超大堆(>100GB)的延迟控制更具挑战;
  • 与 Java HotSpot 的 G1/ZGC 等相比,Go GC 更强调简单性、确定性与部署友好性,牺牲部分吞吐量换取更低的尾部延迟(P99)和更少的调优参数(主要仅需关注 GOGC)。

总结而言:Go 的垃圾回收是一套由 runtime 原生实现、深度绑定操作系统线程、以低延迟为目标的并发标记清除系统。它既不是“黑盒线程”,也不是用户可见的 goroutine,而是现代编译型语言中“自带轻量级运行时”范式的典型体现——无需 VM,却依然提供安全、自动、高效的内存管理。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

95

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

106

2025.09.18

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

443

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

605

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

443

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

605

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

765

2023.08.10

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

497

2023.08.14

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.4万人学习

C# 教程
C# 教程

共94课时 | 11.2万人学习

Java 教程
Java 教程

共578课时 | 81.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号