标签 标准库 下的文章

“学习 Go 毁掉了我钟爱的其他语言”:一场网络热议揭示 Go 开发者真正的爱与痛

本文永久链接 – https://tonybai.com/2025/11/11/go-developers-love-pain-online-debate

大家好,我是Tony Bai。

近日,一条开发者 Mario Verbelen 发布的推文——“学习 Go 毁掉了我钟爱的其他语言,但我不在乎。因为它真的太棒了。”——意外地在技术圈引起了一场关于 Go 语言的集中讨论。上百的开发者涌入评论区,分享着他们与 Go 的“爱恨情仇”。这场热议如同一面镜子,清晰地映照出 Go 在 2025 年的开发者心中究竟占据着怎样的位置。

它不仅仅是一句玩笑或一句赞美,更像是一个“投名状”,代表着一种特定的开发哲学。

在本文中,我们将深入这场热议的中心,剖析开发者们口中 Go “毁灭性”吸引力的来源,探讨其在与其他主流语言的比较中展现出的独特价值,并审视那些至今仍在社区中引发激烈辩论的核心议题。

Go 的“甜蜜点”:Python 的生产力与 C 的性能

在这场讨论中,一个反复出现的核心观点是:Go 完美地击中了一个业界长期寻求的“甜蜜点”。正如一位开发者所言:“我真的很喜欢 Python,但当你遇到性能瓶颈不得不切换到 C 时,这很烦人。Go 几乎和 Python 一样高效,同时又和 C 一样快,这正是我想要的。”

这句评论精准地概括了 Go 的核心价值主张(即“爱”之所在):

  • 简洁的语法与强大的工具链: 许多开发者认为,Go 之所以能媲美 Python 的生产力,得益于其极简的语言设计、快速的编译/调试循环以及“开箱即用”的强大标准库和工具集。一位开发者甚至感叹:“Go 是第一门感觉像一个完整操作系统的语言——线程、异步、发布/订阅、服务、管道、定时任务,所有这些都在一个进程内。”
  • 毫不妥协的性能: 与此同时,Go 能够编译成无依赖的单一二进制文件,其性能表现足以比肩 C/C++。这使得开发者无需在开发速度和运行速度之间做出痛苦的抉择。
  • “无聊”即是美德: 相较于其他语言生态中层出不穷、令人眼花缭乱的“时髦框架”,Go 推崇的是清晰、直接、甚至略显“无聊”的代码。正如评论所说,“笨拙/无聊的代码就是最好的代码”。这种对朴素和可读性的追求,使得大型项目和团队协作变得异常轻松。

激烈的哲学辩论:GC、if err != nil 与泛型

当然,没有任何一门语言是完美的。这场讨论也成为了 Go 核心设计哲学争议(即“痛”之所在)的缩影。

垃圾回收 (GC):是福是祸?

一位用户指出:“与 Rust/Zig/C 等语言相比,Go 唯一的大缺点就是 GC”。这代表了一部分追求极致性能和内存控制的开发者的心声。然而,立刻有开发者反驳:“GC 并没有妨碍我,那只是 Go 早期的事,现在的实现已经非常好了。” 这场辩论揭示了 Go 的一个关键取舍:用一个高度优化的现代 GC 来换取巨大的开发便利性,放弃手动内存管理的复杂性和风险。 对于绝大多数后端应用而言,这笔交易显然是划算的。

if err != nil:是“圣杯”还是“紧箍咒”?

Go 标志性的错误处理模式 if err != nil 再次成为焦点。有新用户开玩笑说:“看来你还没熟悉 if err != nil,祝你好运。” 而资深 Go 开发者则回应:“你需要拥抱它,这是一个强大的思想。”

这场看似调侃的互动背后,是 Go 对待错误的严肃态度。Go 强制开发者显式地处理每一个可能的错误,拒绝了 try-catch 带来的隐式控制流。虽然这有时会显得冗长,但它换来的是代码的健壮性和确定性,这对于构建可靠的系统至关重要。

泛型:爱它还是恨它?

自 Go 1.18 引入泛型以来,社区对此的看法仍存在分歧。一位开发者怀旧地表示:“我想回到 Go 还没有泛型的那个时代。” 这代表了一种对 Go 极致简单的怀念。而另一方则认为:“我发现(泛型)的实现很好”。这反映了 Go 在演进过程中的平衡艺术:在不破坏语言核心简单性的前提下,谨慎地引入新特性以解决实际问题。

生态位:在 Rust、Python 和 C 的世界里,Go 的位置在哪?

这场讨论最精彩的部分,莫过于 Go 在与其他主流语言的横向对比中展现出的清晰定位。

  • Go vs. Rust: 该帖子本身就引用了一位Rust开发者的观点:“不幸的是,学习 Rust 毁掉了几乎所有其他语言。” 这句话开启了 Go 和 Rust 的经典对比。社区的共识是,Rust 提供了无与伦比的内存安全和零成本抽象,但在学习曲线(尤其是所有权和借用检查器)和开发心智负担上远超 Go。Go 则凭借其简单性和 Goroutine 并发模型,在网络服务和分布式系统领域提供了“足够好”的性能和更高的开发效率。
  • Go vs. Python: 如前所述,Go 已成为许多 Python 开发者在遇到性能瓶颈时的首选“升级”路径。它保留了 Python 的部分开发乐趣,同时提供了系统级语言的性能。
  • Go vs. C: 本帖作者 Mario Verbelen 精辟地总结道:“写脚本语言感觉像戴着手铐,而写 C 感觉像是在没有保护的情况下用胶带粘合各种库。” Go 则提供了 C 的性能,却拥有一个安全的、现代化的标准库和工具生态。

小结:一种务实的“毁灭性”吸引力

“学习 Go 毁掉了我钟爱的其他语言”,这句网络热梗的背后,并非是对其他语言的贬低,而是一种对 Go 核心哲学的深度认同。Go 的吸引力源于其毫不妥协的务实主义

它不追求成为最精巧、最纯粹或功能最丰富的语言。相反,它专注于解决软件工程中最常见、最头痛的问题:快速编译、轻松部署、简单并发、高效性能和大规模团队协作。它用一点“无聊”和“冗长”,换来了巨大的工程确定性和生产力。

对于那些厌倦了复杂构建系统、重量级框架和隐晦运行时行为的开发者而言,Go 提供了一种返璞归真的体验。正是这种聚焦于核心问题的“毁灭性”吸引力,让无数开发者在接触 Go 之后,便再也“回不去了”。

资料链接:https://x.com/MarioVerbelen/status/1984164183395758564


你的Go技能,是否也卡在了“熟练”到“精通”的瓶颈期?

  • 想写出更地道、更健壮的Go代码,却总在细节上踩坑?
  • 渴望提升软件设计能力,驾驭复杂Go项目却缺乏章法?
  • 想打造生产级的Go服务,却在工程化实践中屡屡受挫?

继《Go语言第一课》后,我的《Go语言进阶课》终于在极客时间与大家见面了!

我的全新极客时间专栏 《Tony Bai·Go语言进阶课》就是为这样的你量身打造!30+讲硬核内容,带你夯实语法认知,提升设计思维,锻造工程实践能力,更有实战项目串讲。

目标只有一个:助你完成从“Go熟练工”到“Go专家”的蜕变! 现在就加入,让你的Go技能再上一个新台阶!


想系统学习Go,构建扎实的知识体系?

我的新书《Go语言第一课》是你的首选。源自2.4万人好评的极客时间专栏,内容全面升级,同步至Go 1.24。首发期有专属五折优惠,不到40元即可入手,扫码即可拥有这本300页的Go语言入门宝典,即刻开启你的Go语言高效学习之旅!


商务合作方式:撰稿、出书、培训、在线课程、合伙创业、咨询、广告合作。如有需求,请扫描下方公众号二维码,与我私信联系。

Go 标准库将迎来 Zstandard:性能超越 Gzip,让你的应用更快、更省

本文永久链接 – https://tonybai.com/2025/11/08/proposal-zstd

大家好,我是Tony Bai。

在 Go 的世界里,一项被社区翘首以盼的提案在沉寂一年后,终于迎来了决定性的进展。2024 年,将 Zstandard 压缩算法纳入标准库的提案(#62513)被正式 Accept,但在那之后便鲜有动静。直到最近的 Go 编译器与运行时会议纪要中透露,这项工作将由社区的明星开发者 Klaus Post 主导推进。

这意味着,在未来的 Go 版本中,开发者将能开箱即用地获得一个官方维护、安全可靠且性能卓越的压缩工具。这不仅是对 Go 生态的一次重要补强,更将直接为无数 Go 应用带来性能提升、带宽节约和成本削减,真正实现“更快、更省”的承诺。

同时,这个提案背后曲折的历程——从激烈的技术选型辩论,到精雕细琢的 API 设计,再到因核心团队资源紧张而搁置,最终由社区力量重新激活——本身就是一幅展现 Go 生态演进的生动图景。

在本文中,我们将探讨 Zstandard 脱颖而出的技术优势,剖析其在工业界的成功案例,并揭示 compress/zstd 标准库从提案、API 设计到最终由社区力量重启的完整历程。

Zstandard:为何是它,而非其他?

在决定为标准库引入新的压缩算法时,Go 团队面临着众多选择。提案发起者 dsnet 在讨论中进行了一次精彩的“选美”,清晰地阐述了为何 Zstandard (Zstd) 能够脱颖而出:

  • Zstandard (Zstd): 由 Facebook (现 Meta) 开发并开源,拥有极佳的压缩/解压速度和出色的压缩比。更重要的是,它有正式的 RFC 规范(RFC 8878),这对于标准库实现的“正确性”至关重要。
  • Brotli: 同样优秀,但在设计上更偏向 Web 静态内容,且其庞大的静态字典(约 120KiB)与 Go 追求小体积静态二进制文件的哲学相悖。
  • XZ (LZMA): 拥有极高的压缩比,但代价是极其缓慢的压缩和解压速度,不适合通用场景。且缺乏正式的、明确的规范。
  • Snappy / LZ4: 追求极致的速度,但在压缩比上做出了巨大牺牲,应用场景相对小众。

Zstd 巧妙地结合了 LZ77 算法和一种名为 ANS (Asymmetric Numeral Systems) 的现代熵编码技术,在性能、压缩比和资源消耗之间取得了近乎完美的平衡,使其成为替代 Gzip 的“天选之子”。

注:截至Go 1.25.3版本,Go compress目录下提供了多种压缩算法的实现:bzip2实现了Burrows-Wheeler变换及霍夫曼编码;flate提供了DEFLATE算法核心,结合了LZ77和霍夫曼编码;gzip和zlib则分别将DEFLATE算法封装为gzip文件格式和zlib数据流格式;lzw实现了Lempel-Ziv-Welch算法。这些包共同为Go语言提供了多样化的数据压缩与解压缩能力。

注:Zstandard最新RFC规范为RFC 9659

工业界验证:Discord 与 Cloudflare 的性能飞跃

理论上的优势必须经过实践的检验。Zstd 在工业界的应用早已硕果累累。

  • **Discord 的 40% 带宽削减:** 通讯巨头 Discord 在将其实时网关的压缩算法从 zlib (Gzip) 迁移到流式 Zstandard 后,获得了惊人的收益。对于核心的 MESSAGE_CREATE 事件,压缩时间缩短了一半以上,负载体积也显著减小。这直接转化为更低的服务端 CPU 占用和客户端带宽节省,最终实现了 整体 Websocket 流量降低 40% 的壮举。

  • **Cloudflare 的容器镜像加速:** 在其全球容器平台上,Cloudflare 需要快速分发巨大的 AI 模型镜像(常超过 15GB)。通过将镜像层压缩算法从 Gzip 更换为 Zstd,一个 30GB 镜像的拉取时间从 8 分钟骤降至 4 分钟,速度翻倍,极大地提升了全球调度的灵活性和响应速度。

这些案例雄辩地证明,Zstd 是为现代高吞吐量、低延迟应用而生的。

API 设计的艺术:一场关于简洁、安全与未来的辩论

将新包引入标准库,API 的设计是重中之重。#62513 的讨论串完整记录了 compress/zstd API 从雏形到最终形态的演进过程。

核心原则:安全与一致性

提案伊始,就确立了两大基石:

  1. 安全优先: 标准库实现必须是纯 Go版本,不使用 unsafe 或汇编。dsnet 强调:“Go 社区调查一致显示,安全性比性能更重要。” 这意味着标准库版本追求的是可审查性、可维护性和跨平台的一致性,而非极致的性能。
  2. API 一致性: 新 API 应与 compress/gzip、compress/flate 等现有包保持风格统一,降低开发者的学习和迁移成本。

社区的声音:Klaus Post 的关键输入

在讨论中,github.com/klauspost/compress 系列库的作者 Klaus Post 扮演了关键角色。他的库是 Go 社区公认的最高性能压缩实现,其丰富的实战经验为标准库的设计提供了宝贵视角。

Klaus 指出,他自己的库 API 相对复杂,是因为支持多线程、异步等高级特性。他赞同标准库应剥离这些复杂性,提供一个完全同步的、线程安全的 API。同时,他也对字典(Dictionary)功能的 API 设计提出了深刻见解,强调了字典预处理的开销问题,这直接影响了后续 API 的设计。

最终定稿的 API

经过多轮讨论,由 Russ Cox (rsc) 总结并最终被接受的 API 形态如下(并非最终版):

package zstd

const (
    NoCompression      = 0
    BestSpeed          = 1
    BestCompression    = 9
    DefaultCompression = -1
)

type Dict struct { /* ... */ }
func ParseDict(enc []byte) (*Dict, error)
// ... 可能还包含 Marshal/Unmarshal 方法

type Reader struct { /* ... unexported fields ... */ }
func NewReader(r io.Reader) (*Reader, error)
func (z *Reader) Reset(r io.Reader) error
func (z *Reader) AddDict(*Dict)
func (z *Reader) SetRawDict([]byte)
func (z *Reader) Read(p []byte) (int, error)
func (z *Reader) Close() error

type Writer struct { /* ... unexported fields ... */ }
func NewWriter(w io.Writer) *Writer
func (z *Writer) Reset(w io.Writer)
func (z *Writer) SetLevel(int) error
func (z *Writer) AddDict(*Dict)
func (z *Writer) SetRawDict([]byte)
func (z *Writer) Write([]byte) (int, error)
func (z *Writer) Flush() error
func (z *Writer) Close() error

这个设计体现了 Go 标准库的哲学:

  • Setter 模式: 采用 SetLevel、AddDict 等方法进行配置,而不是更复杂的构造函数重载或函数式选项,兼顾了灵活性和简洁性。
  • 独立的 Dict 类型: 将字典抽象为 Dict 类型,通过 ParseDict 进行预处理。这解决了 Klaus 提出的“重复解析字典开销大”的问题,允许用户一次解析,多次复用。
  • 错误处理: 关键配置(如 SetLevel、ParseDict)返回 error,增强了 API 的健壮性。

漫长的等待与社区英雄的登场

提案于 2024 年被接受,为何直到 2025 年底才真正启动?这背后反映了 Go 核心团队面临的现实挑战。Go 团队规模精简,核心成员的精力需要分配给语言、编译器、运行时等更高优先级的任务。提案发起者 dsnet 也深度参与了 json/v2 等重大项目,无暇分身。

在此期间,Klaus Post 主动请缨,表示愿意贡献一个精简版的、符合标准库要求的实现。然而,这个提议在当时并未得到明确的推进信号。

转机出现在 2025 年 11 月的 Go 团队内部会议。纪要显示,团队终于有带宽来审查社区对 compress/flate 和 compress/zstd 的贡献。会议明确提到:“很高兴有社区审查。我们能去问问 k8s 的人吗?”(意指寻求更多社区的反馈和测试)。这标志着官方正式为 Klaus Post 的贡献打开了大门。随后Klaus Post也给出了自己的贡献时间表,大约在2026年Q1提交第一版实现给Go团队审查。

小结:一次迟到但意义非凡的升级

compress/zstd 的加入,对 Go 生态而言,是一次迟到但意义非凡的升级。它不仅仅是增加了一个功能包,更是一次:

  • 技术的现代化: 用一个在性能和效率上全面超越 Gzip 的现代算法,武装 Go 的标准库。
  • 生态的成熟: 将社区经过千锤百炼的最佳实践,以安全、稳健的方式融入官方标准。
  • 模式的探索: 展示了在核心团队资源有限的情况下,如何通过与社区领袖的协作,共同推动语言生态向前发展。

对于广大 Go 开发者来说,未来已来。不久之后(或许在 Go 1.27),我们将能以最简单、最 Go-like 的方式,为我们的应用插上 Zstandard 的翅膀,轻松实现性能提升与成本节约。这无疑是 Go 社区协作精神的又一次伟大胜利。

参考资料

  • https://github.com/golang/go/issues/62513
  • https://blog.cloudflare.com/container-platform-preview
  • https://discord.com/blog/how-discord-reduced-websocket-traffic-by-40-percent
  • https://www.rfc-editor.org/rfc/rfc8878

你的Go技能,是否也卡在了“熟练”到“精通”的瓶颈期?

  • 想写出更地道、更健壮的Go代码,却总在细节上踩坑?
  • 渴望提升软件设计能力,驾驭复杂Go项目却缺乏章法?
  • 想打造生产级的Go服务,却在工程化实践中屡屡受挫?

继《Go语言第一课》后,我的《Go语言进阶课》终于在极客时间与大家见面了!

我的全新极客时间专栏 《Tony Bai·Go语言进阶课》就是为这样的你量身打造!30+讲硬核内容,带你夯实语法认知,提升设计思维,锻造工程实践能力,更有实战项目串讲。

目标只有一个:助你完成从“Go熟练工”到“Go专家”的蜕变! 现在就加入,让你的Go技能再上一个新台阶!


想系统学习Go,构建扎实的知识体系?

我的新书《Go语言第一课》是你的首选。源自2.4万人好评的极客时间专栏,内容全面升级,同步至Go 1.24。首发期有专属五折优惠,不到40元即可入手,扫码即可拥有这本300页的Go语言入门宝典,即刻开启你的Go语言高效学习之旅!


商务合作方式:撰稿、出书、培训、在线课程、合伙创业、咨询、广告合作。如有需求,请扫描下方公众号二维码,与我私信联系。

如发现本站页面被黑,比如:挂载广告、挖矿等恶意代码,请朋友们及时联系我。十分感谢! Go语言第一课 Go语言进阶课 AI原生开发工作流实战 Go语言精进之路1 Go语言精进之路2 Go语言第一课 Go语言编程指南
商务合作请联系bigwhite.cn AT aliyun.com

欢迎使用邮件订阅我的博客

输入邮箱订阅本站,只要有新文章发布,就会第一时间发送邮件通知你哦!

这里是 Tony Bai的个人Blog,欢迎访问、订阅和留言! 订阅Feed请点击上面图片

如果您觉得这里的文章对您有帮助,请扫描上方二维码进行捐赠 ,加油后的Tony Bai将会为您呈现更多精彩的文章,谢谢!

如果您希望通过微信捐赠,请用微信客户端扫描下方赞赏码:

如果您希望通过比特币或以太币捐赠,可以扫描下方二维码:

比特币:

以太币:

如果您喜欢通过微信浏览本站内容,可以扫描下方二维码,订阅本站官方微信订阅号“iamtonybai”;点击二维码,可直达本人官方微博主页^_^:
本站Powered by Digital Ocean VPS。
选择Digital Ocean VPS主机,即可获得10美元现金充值,可 免费使用两个月哟! 著名主机提供商Linode 10$优惠码:linode10,在 这里注册即可免费获 得。阿里云推荐码: 1WFZ0V立享9折!


View Tony Bai's profile on LinkedIn
DigitalOcean Referral Badge

文章

评论

  • 正在加载...

分类

标签

归档



View My Stats