当前位置: 首页 > article >正文

Go语言的垃圾回收(GC)机制的迭代和优化历史

Go语言的垃圾回收(GC)机制自Go语言发布以来经历了多次重要的迭代和优化,以提高性能和减少程序运行时的停顿时间。
以下是一些关键的版本和相应的GC优化:

Go版本GC耗时情况主要改进点
Go 1.0-1.4可能达到几百毫秒至秒级使用简单的标记-清除算法,GC过程会导致程序完全暂停
Go 1.5几十毫秒级别引入并发标记和扫描:实现了完全并发的垃圾回收,包括并发标记(Concurrent Mark)阶段。这大大减少了GC的停顿时间,使得Go程序在运行时更加平滑。
Go 1.6-1.7约10毫秒左右优化了并发GC的实现,减少了内存分配和回收的开销
Go 1.81毫秒以下优化了堆内存的增长策略,使得内存分配更加高效,减少了内存碎片,减少了GC触发频率
Go 1.9亚毫秒级别优化了写屏障(Write Barrier),这是支持并发垃圾回收的一项关键技术,进一步减少了GC的停顿时间。
Go 1.12亚毫秒级别引入了基于页的碎片整理(Page-based Fragmentation),减少了内存碎片,提高了内存使用效率。
Go 1.14亚毫秒级别,部分场景微秒级引入了基于信号的非协作式抢占(Non-cooperative Preemption),这意味着调度器可以更公平地分配CPU时间给Goroutines,减少了长时间运行的Goroutines对GC的阻塞。
Go 1.19亚毫秒级别,部分场景微秒级引入了软内存限制的概念,允许开发者设置应用程序的内存使用上限,GC会根据这个上限来调整其行为,以减少内存使用。

请注意,表中的GC耗时情况是大致估计,实际GC耗时会因应用程序的特性(如内存使用模式、对象生命周期等)而有所不同。

总体趋势是,Go语言的GC性能在各个版本中持续改进,停顿时间显著降低,为开发高性能、低延迟的应用提供了更好的支持。
在实际应用中,建议使用Go的性能分析工具(如pprof)来测量和优化特定应用的GC性能。

随着Go语言的发展,GC的优化一直是Go团队关注的重点之一。每次迭代都旨在减少GC的停顿时间,提高内存管理的效率,使得Go语言更适合开发需要高性能和高并发的应用程序。未来的Go版本预计还会继续在GC性能优化方面取得进展。


http://www.kler.cn/news/314139.html

相关文章:

  • Vision Based Navigation :针对航天领域的基于视觉导航机器学习应用生成训练数据集
  • Redis的AOF持久化、重写机制、RDB持久化、混合持久化
  • Springboot常见问题(bean找不到)
  • C#为任意组件开发登录功能的记录
  • android设置实现广告倒计时功能
  • [Python数据可视化]Plotly Express: 地图数据可视化的魅力
  • 第十九节:学习WebFlux与前端响应式-非阻塞-流式通讯(自学Spring boot 3.x的第四天)
  • Java操控Redis (面经之 使用Redis)
  • 【HTTP】构造HTTP请求和状态码
  • [译] Go语言的源起,发展和未来
  • Rust语言入门第七篇-控制流
  • Highcharts甘特图基本用法(highcharts-gantt.js)
  • 安装黑群晖系统,并使用NAS公网助手访问教程(好文)
  • 【系统架构设计师】虚拟机架构风格
  • 十五、差分输入运算放大电路
  • C++——模板初阶
  • 网页聊天——测试报告——Selenium自动化测试
  • 分类预测|2024年最新优化算法鹦鹉优化器PO|基于鹦鹉优化SVM支持向量机数据分类预测Matlab程序PO-SVM
  • 2024年9月python二级易错题和难题大全(附详细解析)(五)
  • allWebPlugin中间件自定义alert、confirm及prompt使用
  • 力扣1143-最长公共子序列(Java详细题解)
  • 分布式光伏发电系统如何确保电能质量达到并网要求?
  • Tiny-universe学习笔记1:Qwen-blog
  • 数据飞轮:打造业务增长的持续循环
  • C++——string的了解和使用
  • 相见恨晚的一本书《纳瓦尔宝典:财富与幸福指南》
  • 内网渗透- 内网渗透的基本知识
  • 【物联网】时序数据库InfluxDB解析及1.x版本与2.x版本区别详解
  • Docker 笔记
  • java计算字符串中大写字母的个数