写点什么

Go 语言的历史回顾

  • 2019-09-06
  • 本文字数:2543 字

    阅读完需:约 8 分钟

Go语言的历史回顾

Go 的发展历史对所有开发者来说都是必备知识。了解 Go 语言历年来各版本的主要变化,将有助于深入了解使用 Go 语言所需要的思维方式以及各版本的优缺点。你可以通过访问特定版本的更新日志链接查看更多详细内容。

Go 1.0 - 2012 年 3 月:

随着 Go 第一个版本发布的还有一份兼容性说明文档。该文档说明,Go 的未来版本会确保向后兼容性,不会破坏现有程序。


此版本中已经包含 go tool pprof 命令,它是Google的pprof C++分析器的一个变种;同时还包含 go vet 命令(之前的是 go tool vet),它可以报告程序包中可能存在的错误。

Go 1.1 - 2013 年 5 月:

这个版本的 Go 致力于增强语言特性(编译器、垃圾回收机制、映射、goroutine 调度器)与性能。下面是改进的图例:



图源


此版本内置了竞态检测器,这已成为 Go 语言必不可少的工具。


你可以通过这篇文章:“Race Detector with ThreadSanitizer” 了解更多关于竞态检测器的信息。


重新编写后的Go的调度器性能有了显著提高。调度器目前的设计如下:



图源


M 是操作系统线程,P 表示一个处理器(P 的数量不能超过 GOMAXPROCS),其中每个 P 对应一个本地 go 协程队列。1.1 版本之前,P 的概念没有被引入,go 协程在全局范围通过存在于全局的单个互斥锁管理。这次改进实现了“任务窃取(work-stealing)”,允许一个 P 处理队列“窃取”另外一个 P 处理队列的协程任务。



图源


有关 Go 调度器与任务窃取的更多信息,请查看Jaana B.Dogan的"Go的任务窃取调度器”文章。

Go 1.2 - 2013 年 12 月:

test 命令支持代码覆盖率报告,并提供新的 go tool cover 命令输出代码测试覆盖率的统计信息:



图源


同时可以提供代码测试覆盖信息:


Go 1.3 - 2014 年 6 月:

堆栈管理在此版本中得到了重要改善。堆栈现在会分配连续的内存片段,并提高了分配效率。这使得 Go 语言在下个版本中将堆栈大小减少到 2KB。


这同时改进了某些组件中堆栈的错误拆分所导致的性能下降问题,此类问题会在堆栈密集分配/释放状态下出现。以下 json 包的例子展示了性能对于堆栈大小的相关度:



图源:contiguous stack


引入连续堆栈的机制修复了这类组件的性能问题。下面是另一个 html/template 包的例子,它也展示出了性能对于堆栈大小的敏感度:



想了解更多信息,可阅读文章 “How Does the Goroutine Stack Size Evolve?”


这个版本同时发布了 sync 包的 Pool 组件。通过 Pool,我们可以复用代码结构,减少分配资源的数量,并且该组件随后成为 Go 生态系统中许多改进的来源,如标准库中的 encoding/json 和 net/http 包,或者 Go 社区中的 zap 等包。


想了解更多信息,可阅读文章 Understand the Design of Sync.Pool”.


Go 团队同时改进了channel的实现,提升了它的性能。以下是 Go 1.2 与 Go 1.3 的基准测试对比:



Go 1.2 与 Go 1.3 版本间 channel 的性能对比

Go 1.4 - 2014 年 12 月:

Android 的官方支持包golang.org/x/mobile随着这个版本一同发布,使得开发者可以仅用 GO 代码编写简单的 Android 应用。此外,之前用 C 和汇编语言编写的大多数运行时已转换为用 Go 语言实现。由于使用了更精准的垃圾收集器,堆栈大小减少了 10~30%。


虽然与新版本无关,Go 的项目代码管理工具从 Mercurial 切换为 Git,与此同时,项目也从 Google Code 迁移到了 Github 上。


Go 还发布了 go generate 命令,此命令会扫描//go:generate 指令提供的信息生成代码,简化了代码生成的方式。


关于代码生成的更多信息,可参考Go的官方博客这篇文章

Go 1.5 - 2015 年 8 月:

从该版本开始,Go的发布时间延迟了两个月,调整为每年 8 月和 2 月发布新版本:



图源


在此版本中,垃圾回收器被完全重新设计实现。归功于基于并发的回收器,垃圾回收延迟被显著降低。以下来自于 Twitter 生产环境服务器的例子,其中 GC 延迟从 300 毫秒降低到 30 毫秒:



图源


这个版本还发布了执行追踪记录,可通过 go tool trace 命令获取。追踪信息可在测试或运行期间生成,展示在浏览器窗口中:



原始的Go执行跟踪文件

Go 1.6 - 2016 年 2 月:

在使用 HTTPS 的情况下增加对于 HTTP/2 协议的默认支持是这次更新的最重要更改。同时,再一次降低了垃圾回收器的延迟:



图源

Go 1.7 - 2016 年 8 月:

此版本发布了context包,它可以为用户提供处理超时和任务取消的机制。


想了解更多,可阅读文章“Context and Cancellation by Propagation.”


编译工具链在这次更新中得到了优化:加速了编译过程;降低了编译后二进制文件的大小,幅度可达 20~30%。

Go 1.8 - 2017 年 2 月:

此版本包含对于垃圾回收器的改进,使得两次垃圾回收的暂停时间减小到了毫秒级:



图源


同时识别了剩余仍未解决的暂停模式,并在下一个版本中得到修复。修复后,通常情况下暂停时间能控制在 100 微秒左右。


此版本还改进了 defer 函数:



图源

Go 1.9 - 2017 年 8 月:

此版本中增加了类型别名:


type byte = uint8
复制代码


这表示 byte 是 uint8 的类型别名。


sync 包增加了保证并发访问安全性的Map类型。

Go 1.10 - 2018 年 2 月:

test 包增加了新的智能缓存机制。现在成功完成的测试结果会被缓存,这样 test 包会自动跳过未做更改的代码的相关测试用例,节省了开发人员运行测试套件的时间:


first run:ok      /go/src/retro 0.027s
second run:ok /go/src/retro (cached)
复制代码


与此同时,go build 命令会缓存最近构建过的包,从而加快了构建过程。新版本不包含垃圾回收器的实质性改动,但为它重新定义了 SLO(服务级别目标):



图源

Go 1.11 - 2018 年 8 月:

Go 1.11 版本引入了一个重要功能:Go模块。Go 模块产生是为了应对 Go 语言社区面临的一大挑战。这是通过调查问卷收集到的:



2018年Go语言调查


第二个新特性是增加了实验性的WebAssembly支持,它可以帮助开发人员将 Go 程序编译为兼容四个主要 Web 浏览器的二进制程序。

Go 1.12 - 2019 年 2 月:

此版本在analysis包的基础上重写了 go vet 命令。这个包有着更大的灵活性,允许开发人员编写自己的代码检查工具。

Go 1.13 - 2019 年 9 月:

sync 包的 Pool 组件得到了改进,使得池中的资源不会在垃圾回收的时候被清除。通过新机制里引入的缓存,两次垃圾回收之间没有被使用过的实例才会被清除。


同时重写了逃逸分析逻辑,使得 Go 程序减少了堆上的分配次数。以下是新的逃逸分析基准测试结果:



图源


原文链接:


Go: Retrospective


2019-09-06 11:427115

评论 1 条评论

发布
用户头像
写的真不错,翻译的也好
2022-02-11 10:34
回复
没有更多了
发现更多内容

大前端—2022明星项目,2023展望

非喵鱼

JavaScript Vue 前端 React 前沿技术

使用MinIO构建分布式文件系统来一次分布式文件系统实战!

风铃架构日知录

Java 程序员 分布式 分布式系统 IT

GAN:生成对抗网络 Generative Adversarial Networks

代码的路

神经网络

RatingBar(星级评分条)

向阳逐梦

Android Studio 星级评分条 ratingbar

项目制实践如何助力组织进化

feijieppm

项目管理 研发效能 技术管理 文化 & 方法 效能度量

DW-Siam:Deeper and Wider Siamese Networks for Real-Time Visual Tracking 更宽更深的孪生网络

代码的路

神经网络

效能改进中的度量实践

feijieppm

项目管理 研发效能 技术管理 文化 & 方法 效能度量

DIMP:Learning Discriminative Model Prediction for Tracking 学习判别模型预测的跟踪

代码的路

神经网络

阿里云AIoT 经典基础知识 快问快答——基础知识

阿里云AIoT

Serverless 物联网 API 消息中间件 弹性计算

天翼云荣获2022年度“边缘计算先锋企业”“分布式云先锋企业”称号!

天翼云开发者社区

大规模 Kubernetes 集群故障注入的利器-ChaosBlade

阿里巴巴中间件

阿里云 Kubernetes 云原生 ChaosBlade

微服务引擎 MSE 升级至 3.0:降低微服务在云原生时代的演进成本

阿里巴巴中间件

阿里云 微服务 云原生

TapTap算法平台的 Serverless 探索之路

Serverless Devs

Java高手速成 | 实现人物拼图游戏

TiAmo

Java 拼图

混沌演练实践(一)

京东科技开发者

测试 混沌工程 系统 混沌测试 企业号 1 月 PK 榜

如何利用浮动容器制作悬浮下拉菜单?

Towify

Higress 开源后,我们整理了开发者最关心的 15 个问题

阿里巴巴中间件

阿里云 云原生 Higress

容器服务与达摩院合作 AHPA 获 AAAI 2023 IAAI人工智能创新应用奖

阿里巴巴中间件

阿里云 容器 云原生

2023年了 对Go做一个全网最全的总结

卡二条

Go Go Concurrency Patterns Go web

安全可信| 密评合规!天翼云全栈混合云通过商用密码应用安全性评估!

天翼云开发者社区

2023-01-11:体育馆的人流量。编写一个 SQL 查询以找出每行的人数大于或等于 100 且 id 连续的三行或更多行记录。返回按 visit_date 升序排列 的结果表。 DROP TAB

福大大架构师每日一题

MySQL 福大大

MarkDown简明语法手册

代码的路

markdown

事件总线 + 函数计算构建云上最佳事件驱动架构应用

Serverless Devs

IoTLink v1.2.1 最新公告

山东云则信息科技

Java 物联网 springboot

阿里巴巴重磅开源云原生网关: Higress

阿里巴巴中间件

阿里云 云原生 Higress

应用 Serverless 化,让业务开发心无旁骛

阿里巴巴中间件

阿里云 Serverless 云原生

问题盘点|使用 Prometheus 监控 Kafka,我们该关注哪些指标

阿里巴巴中间件

kafka 阿里云 云原生 Prometheus

IoTLink 轻量级的物联网综合业务支撑平台

山东云则信息科技

Java 物联网 spring-boot

2023年有哪些具备潜力的加密投资标的?

股市老人

「认知」打工人的自我修养

知了一笑

职场 认知

GA-RPN:Region Proposal by Guided Anchoring 引导锚点的建议区域网络

代码的路

神经网络

Go语言的历史回顾_编程语言_Vincent Blanchon_InfoQ精选文章