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

server/2024/9/22 10:38:30/

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.ppmy.cn/server/120244.html

相关文章

传输层协议(TCP和UDP)

目录 一、UDP 1、UDPAPI 2、UDPAPI的使用 二、TCP 1、TCPAPI 2、TCP的相关特性 2.1 确认应答 2.2 超时重传 2.3 连接管理(三次握手,四次挥手) 2.4 滑动窗口 2.5 流量控制 2.6 拥塞控制 2.7 延时应答 2.8 捎带应答 2.9 面向字节…

flink 批量写clickhouse

idea maven 依赖 <dependency> <groupId>ru.yandex.clickhouse</groupId> <artifactId>clickhouse-jdbc</artifactId> <version>0.2.4</version> </dependency> val clickhouseUri "jdbc:clickhouse://host:8123/aso?…

Python爱心射线(完整代码)

目录 系列目录 写在前面​ 完整代码 下载代码 代码分析 写在后面 系列目录 序号直达链接表白系列1Python制作一个无法拒绝的表白界面2Python满屏飘字表白代码3

云原生(Cloud Native)简介及相关技术

云原生&#xff08;Cloud Native&#xff09;简介及相关技术 什么是云原生&#xff1f; 云原生&#xff08;Cloud Native&#xff09;是一种设计和开发应用程序的方法&#xff0c;旨在充分利用云计算的弹性、可扩展性和分布式架构优势。通过采用微服务架构、容器化、持续集成…

docker入门总结(附错误处理,持续更新)

安装、启动、卸载 卸载掉旧版本的 Docker yum remove -y docker docker-client docker-client-latest docker-common docker-latest docker-latest-logrotate docker-logrotate docker-selinux docker-engine-selinux docker-engineDocker安装&#xff08;选其一&#xff09;…

Codeforces Round 973 (Div. 2) - D题

传送门&#xff1a;Problem - D - Codeforces 题目大意&#xff1a; 思路&#xff1a; 尽量要 最大值变小&#xff0c;最小值变大 即求 最大值的最小 和 最小值的最大 -> 二分答案 AC代码&#xff1a; 代码有注释 #include<bits/stdc.h> using namespace std; #…

ccfcsp-202406(1、2、3、4、5)

矩阵重塑&#xff08;其一&#xff09; #include <bits/stdc.h> using namespace std; int main() {int n,m,p,q;cin >> n >> m >> p >> q;vector<int> vec(n * m);vector<vector<int>> res(p, vector(q,0));int k 0;for(in…

Spring系统学习(一)——初识Spring框架

1. Spring 框架概述 1.1 什么是 Spring&#xff1f; Spring 是一个流行的基于 Java 的开源框架&#xff0c;旨在简化企业级应用程序的开发。最初&#xff0c;它是为了简化 Java 企业版&#xff08;Java EE&#xff09;的复杂性而设计的&#xff0c;经过不断发展&#xff0c;S…