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

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.lryc.cn/news/445953.html

相关文章:

  • thinkphp8 从入门到放弃(后面会完善用到哪里写到哪)
  • 对于电商跨境电商独立站中源代码建站和SaaS建站的区别
  • 使用vite+react+ts+Ant Design开发后台管理项目(二)
  • C++之 string(中)
  • 双向链表的基本结构及功能实现
  • stm32定时触发软件中断
  • blender设置背景图怎么添加?blender云渲染选择
  • MMD模型及动作一键完美导入UE5-Blender方案(三)
  • 网络安全自学入门:(超详细)从入门到精通学习路线规划,学完即可就业
  • 如何在O2OA中使用ElementUI组件进行审批流程工作表单设计
  • 三、LLM应用开发准备工作
  • 机器学习-可解释性机器学习:随机森林与fastshap的可视化模型解析
  • 使用Assimp加载glb/gltf文件,然后使用Qt3D来渲染
  • vue实现左侧数据拖拽到右侧区域,且左侧数据保留且左侧数据不能互相拖拽改变顺序
  • 人工智能与机器学习原理精解【21】
  • 【MySQL 01】数据库基础
  • C语言字符学习中级使用库解决问题
  • 网络管理:网络故障排查指南
  • Springboot常见问题(bean找不到)
  • 架构设计笔记-5-软件工程基础知识
  • Solidity——抽象合约和接口详解
  • Fyne ( go跨平台GUI )中文文档-入门(一)
  • Google 扩展 Chrome 安全和隐私功能
  • css 缩放会变动的需要使用转换
  • (17)数据库neo4j数据备份
  • 从零开始学习Python
  • 前端框架的对比和选择
  • 《机器学习》周志华-CH7(贝叶斯分类)
  • 【C/C++】错题记录(一)
  • 【代码随想录训练营第42期 Day60打卡 - 图论Part10 - Bellman_ford算法系列运用