标签 Concurrency 下的文章

TypeScript 编译器 Go 重写版提速 10 倍:微软团队深度揭秘幕后工程细节

本文永久链接 – https://tonybai.com/2026/01/27/typescript-compiler-go-rewrite-10x-speed-microsoft-details

大家好,我是Tony Bai。

“JavaScript 是一门很棒的语言,但它并不是为了编写编译器而设计的。”

备受瞩目的 TypeScript 编译器 Go 重写版(代号 TypeScript 7.0)已经取得了惊人的 10 倍性能提升。在最近的 GopherCon 2025 上,来自 Microsoft TypeScript 团队的 Jake Bailey 带来了一场干货满满的分享,深度揭秘了这场跨语言大迁徙背后的工程挑战与技术细节。

为什么最终选择了 Go?庞大的 AST 如何在 Go 中高效表达?又是如何通过并发设计打破 Node.js 的性能枷锁的?本文将带你深入编译器内部,一探究竟。

img{512x368}

缘起:当 JavaScript 触碰到天花板

TypeScript 自 2012 年发布以来,一直采用“自举” (Self-hosting) 的方式,即用 TypeScript 编写 TypeScript 编译器。这带来了巨大的好处:团队能第一时间吃自己的狗粮,社区贡献也极其方便。

然而,JavaScript 并不是为了编写高性能编译器而设计的。随着代码库规模的爆炸式增长(如 VS Code 的 150 万行代码),基于 Node.js 的编译器逐渐触碰到了性能天花板:

  • 单线程与内存限制:JavaScript 无法高效利用多核 CPU,且 Node.js 构建环境(如 Electron)常常面临 4GB 内存上限,导致大型项目编译时频繁 OOM。
  • 昂贵的对象模型:JavaScript 的对象模型开销巨大,而编译器需要创建数以百万计的 AST 节点,这对内存和 GC 都是沉重的负担。
  • 异步的代价:async/await 虽然方便,但带来了著名的“函数着色”问题,且 Promise 对象的分配本身就有非零的运行时开销。

尽管团队已经用尽了 JIT 优化、缓存、单态化 (monomorphization) 等高级手段,但性能提升的边际效应越来越小,OOM 问题依然挥之不去。移植到另外一种语言,成为了打破僵局的唯一选择。

明确目标:新编译器的硬性指标

既然决定要移植到新语言,那么新语言必须解决 JavaScript 的痛点,同时不能丢失现有的优势。团队列出了几条不可妥协的硬性指标:

  1. 极致速度:必须编译为原生机器码 (Native Code),摆脱解释器和 JIT 的预热开销。
  2. 共享内存并发:这是性能翻盘的关键。新语言必须对多线程共享内存有强力支持,以便充分压榨多核性能。
  3. 跨平台支持:必须能运行在所有主流操作系统上,最重要的是——必须能编译为 WebAssembly,以确保在浏览器环境(如 vscode.dev)中的体验。
  4. 无缝移植:鉴于 TypeScript 没有正式的语言规范(Spec),现有的编译器实现就是事实上的规范。因此,新语言必须能够最大程度地保留原有代码的结构和逻辑,以确保行为的一致性。

正是这几条苛刻的标准,将选型的范围迅速缩小。

选型:为什么是 Go?

在考察了 Rust、C#、Zig 等语言后,Go 脱颖而出。Jake 透露了核心的决策逻辑:

  1. 带 GC 的内存管理:编译器涉及大量复杂的、循环引用的数据结构(如 AST 节点),“手动”管理内存(如 Rust)会带来巨大的心智负担和开发成本。Go 的 GC 完美契合这一需求。
  2. 结构相似性:TypeScript 的代码风格(无类、大量函数和接口)与 Go 非常相似。这使得“移植”而非“重写”成为可能。
  3. 学习曲线平缓:团队中大部分是 TypeScript 专家而非系统编程专家。Go 的简单性让团队能迅速上手。
  4. 跨平台与性能:Go 编译为原生机器码,天生支持高并发,且能轻松跨平台(包括编译为 WASM)。

Go完美地契合了TypeScript编译器移植的需求!

早期验证:手写原型与意外惊喜

在决定全面转向 Go 之前,团队并未贸然行动,而是采取了稳健的“原型验证”策略。

他们从编译器的最底层——扫描器 (Scanner) 和解析器 (Parser)——开始,尝试手工将 TypeScript 代码逐行“翻译”为 Go 代码。与此同时,为了确保决策万无一失,还有几位成员试探性地尝试了其他语言方案。

结果令人振奋:即使是初步的手写 Go 代码,解析速度也达到了原版的 5 倍左右!

更重要的是,团队惊喜地发现,手写的 Go 代码在结构和逻辑上与原始的 TypeScript 代码惊人地相似。这种代码形态上的高度一致性,不仅验证了 Go 是正确的选择,更为后续大规模自动化工具的开发注入了强心剂。

移植实战:从 ts-to-go 到并发革命

1. 自动化移植工具:ts-to-go

为了加速迁移,Jake 编写了一个 ts-to-go 工具,能将 TypeScript 代码“直译”为 Go 代码。

  • TS 的 interface -> Go 的 interface
  • TS 的 class -> Go 的 struct + methods
  • 复杂的位运算和逻辑判断 -> 自动转换为 Go 的等价写法

虽然不能 100% 完美转换,但这让团队在初期就能获得一个“虽然丑但能跑”的版本,极大加速了进程。

2. 数据结构的重新设计

在 JavaScript 中,对象是动态的;在 Go 中,一切皆有类型。团队不得不对 AST 的数据结构进行大刀阔斧的改革。

  • 消除 interface 滥用:最初的移植版本大量使用 interface 来模拟 TS 的多态,导致了巨大的内存开销(胖指针)和 nil 检查地狱。
  • 拥抱 struct 嵌入:最终,他们设计了一个基础 Node 结构体,并将其嵌入到所有具体的 AST 节点中。这不仅减少了内存占用,还彻底解决了 nil 接口的问题。

3. 并发:性能提升的核心引擎

这是 Go 带来的最大红利。旧的 TS 编译器是单线程的,解析、绑定、检查、生成都在一条线上排队。

而在 Go 版本中:

  • 解析 (Parsing):每个文件可以独立解析,完全并行。
  • 绑定 (Binding):每个文件的符号绑定也是独立的,完全并行。
  • 类型检查 (Type Checking):这是最难的部分,因为文件间存在复杂的依赖。团队采用了“独立检查器” (Independent Checkers) 的模式,为每组文件分配一个独立的检查器,虽然会有少量重复工作,但实现了高度的并行化。

结果是惊人的:VS Code 的编译时间从 80 秒缩短到了 7 秒,速度提升超过 10 倍!

踩坑与优化:Go 也没那么简单

当然,移植过程并非一帆风顺。Jake 分享了几个典型的“水土不服”案例:

  • 影子变量 (Shadowing):Go 允许在内层作用域遮蔽外层变量(如 err、result等),这导致了无数隐蔽的 Bug。Jake 甚至为此专门写了一个静态分析工具(https://jakebailey.dev/posts/go-shadowing)来抓这些虫子。
  • 方法值的分配:在 Go 中,将方法作为值传递(如 parser.LookAhead)会产生一次内存分配。在一个频繁调用的紧密循环中,这带来了 17% 的性能损耗。解决方案是改回显式的函数调用。
  • 字符串拼接:JavaScript 引擎对字符串拼接有深度优化(Cons-string),而 Go 的 + 操作符则是实打实的内存拷贝。这导致初期的移植版本在处理大量字符串时性能惨不忍睹。

遗憾与取舍:那些我们怀念的 TypeScript 特性

正如 Jake 在演讲中所言,这次迁移是一场巨大的工程胜利,但也是一次充满妥协的旅程。从表达力丰富的 TypeScript 转向“极简主义”的 Go,团队不得不忍痛割爱,放弃了许多令人怀念的语言特性:

  • 编译期空值安全 (Compile-time nil safety):这是团队最怀念的特性。在 Go 中,空指针异常(Panic)依然是悬在头顶的达摩克利斯之剑,而在 TypeScript 中,null/undefined 是类型系统的一部分,能被编译器严格检查。
  • 空值合并与链式调用 (??, ?.):Go 缺乏这些语法糖,使得代码中充斥着冗长的 if x != nil 检查,远不如 TypeScript 优雅。
  • 联合类型与类型收窄 (Union types, narrowing):TypeScript 强大的联合类型让数据建模极其灵活,而在 Go 中,这不得不退化为接口或带有大量字段的结构体。
  • 泛型方法与三元运算符:这些“现代化”特性的缺失,让从前端背景转过来的工程师们颇感不适。

然而,对于编译器团队来说,为了性能,这一切“阵痛”都是值得的。他们用语法的繁琐换取了运行时的极速,这正是工程世界中最经典的“等价交换”。

注:关于泛型方法,Go团队很大可能将在Go 1.27支持!

未来展望:TypeScript 7.0

目前,Go 版本的编译器已经能通过 10 万个测试用例,并在 Slack、Figma 等大厂的内部构建中试运行(Slack 的构建时间从 6 分钟降至 40 秒)。

Microsoft 计划在 TypeScript 6.0 中开始引入一些破坏性变更,为 Go 版本的上位做铺垫。而那个完全由 Go 驱动、极速的编译器,预计将被命名为 TypeScript 7.0

这场从 Node.js 到 Go 的大迁徙,不仅证明了 Go 在复杂编译器领域的工程能力,也为所有面临类似性能瓶颈的团队,提供了一个极具参考价值的范本。

注:微软在2025年12月初发布了TypeScript 7.0的最新进展,大家可以在 https://devblogs.microsoft.com/typescript/progress-on-typescript-7-december-2025/ 这里了解详情。

资料链接:https://www.youtube.com/watch?v=PZm_YbE3fcA


你的“重写”冲动

微软用 Go 重写 TS 编译器,是一次壮士断腕般的成功尝试。在你维护的项目中,是否有那个让你想要“推倒重来”的性能瓶颈?如果让你选,你会
用 Go 还是 Rust 来重写它?

欢迎在评论区分享你的重构经历或选型思考! 让我们一起探讨如何在性能与开发效率之间找到平衡。

如果这篇文章让你对 Go 在大型项目中的潜力有了新的认识,别忘了点个【赞】和【在看】,并转发给你的架构师朋友!


还在为“复制粘贴喂AI”而烦恼?我的新专栏 AI原生开发工作流实战 将带你:

  • 告别低效,重塑开发范式
  • 驾驭AI Agent(Claude Code),实现工作流自动化
  • 从“AI使用者”进化为规范驱动开发的“工作流指挥家”

扫描下方二维码,开启你的AI原生开发之旅。


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

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

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

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

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


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

AI 时代,Go 语言会“失宠”还是“封神”?—— GopherCon 2025 圆桌深度复盘

本文永久链接 – https://tonybai.com/2026/01/20/ai-and-go-opportunities-and-challenges

大家好,我是Tony Bai。

在 AI 的滔天巨浪面前,每一位 Go 开发者心中或许都曾闪过一丝不安:Python 似乎统治了一切,我的 Go 语言技能树还值钱吗?AI 会取代我写代码吗?我该如何在这个喧嚣的时代保持清醒?

GopherCon 2025 的压轴圆桌会议上,一场名为“AI 与 Go:机遇与挑战”的深度对话给出了答案。

嘉宾阵容堪称豪华(从左二到右分别是):

  • Ian Cottrell: Google工程师,现从事 AI Agent 开发
  • Katie Hawkman: 前 Go 团队成员,现 Mercari 平台工程师
  • David Soria Parra: Anthropic 技术专家,MCP (Model Context Protocol) 联合创始人
  • Jaana Dogan: 前 Go团队成员,Google Gemini Serving 团队专家, adk-go项目成员
  • Samir Ajmani: Google Go 团队工程总监

他们没有贩卖焦虑,也没有盲目吹捧,而是用冷静、务实的工程师视角,为我们描绘了 Go 在 AI 时代的真实版图。

Go 的新机遇:AI 基础设施的“基石”

当被问及“Go 能提供什么 Python以及其他编程语言 无法提供的价值”时,嘉宾们的回答出奇一致:生产级的可靠性与并发能力。

Samir Ajmani 提出了一个精准的洞察:Go 的崛起得益于云原生时代的爆发,而 AI 正在带来“第二次云原生机遇”。

  • 现状:目前的 AI/ML 基础设施大量依赖 Python,适合快速原型和实验。
  • 痛点:当这些原型需要走向大规模生产,需要处理高并发推理、构建复杂的 Agent 编排、或者实现像 MCP (Model Context Protocol) 这样需要高度可靠性的协议时,Python 的动态特性和性能瓶颈开始显现。
  • Go 的位置:Go 语言天生的高并发模型、静态类型安全、以及构建大规模分布式系统的基因,使其成为构建 AI 生产基础设施(Serving, Orchestration, Agent Protocols)的完美选择。

Katie 分享了一个真实案例:她在黑客马拉松中选择用 Go 而非 TypeScript 来编写 MCP Server,因为 Go 的代码在处理复杂协议逻辑时更易读、更易维护。

David(Anthropic)就个人经验和观察,认为Go 是目前AI最擅长生成的语言代码之一,这也是Go的一大优势!

Python 也许是 AI 的“训练语言”,但 Go 有望成为 AI 的“运行语言”

职业焦虑:AI 会取代我们吗?

面对“AI 取代程序员”的言论,嘉宾们的态度是——“这只是另一种生产力工具,它改变了工作方式,但提升了人的价值。”

  • Samir Ajmani:未来的软件构建方式可能会变成“组件组装”。但这依然需要懂系统设计、安全性和可靠性的专业人士来构建这些高质量的组件。对于初级开发者,门槛确实变高了(简单的代码生成不再是技能壁垒),但对于具备系统思维的工程师,这是最好的时代。
  • Jaana Dogan (Google):她提出了一个令人耳目一新的视角——“代码写得快了,不仅没让我失业,反而让我更强大了。” AI 极大地缩短了编码时间,这意味着工程师可以更快地去“连接点” (connect the dots):将孤立的组件串联成系统,与更多人协作,验证更多设计想法。个人的产出能力被放大了,你不再是一个单纯的“螺丝钉制造者”,而更容易成为一名“系统架构师”。
  • David Suryapara (Anthropic):作为一名非 Go 核心开发者,David 的观察更为冷静。他认为,纯粹的“代码编写”技能(例如熟练背诵 API、手写 CSS)确实面临贬值。但核心工程能力——如拆解复杂需求、设计分布式系统、处理边缘情况——将变得前所未有的重要。 AI 抬高了入行的地板,但也让那些拥有深厚解决问题能力的工程师变得更加不可替代。
  • Katie Hawkman:写代码从来不是工作中“最难”的部分,而是“最有趣”的部分。真正的难点在于——如何渐进式交付?如何设计良好的 UX?如何优化系统性能?这些是 AI 短期内无法完全替代的工程智慧。
  • Ian Cottrell:我有 40 年的开发经验,每一次生产力工具的飞跃(从汇编到 C,从 IDE 到自动补全),人们都说“不需要程序员了”。结果呢?我们的需求量反而更大了。我们只是在提升期望值,尝试解决更难的问题。

不要试图成为每一个 AI 工具的专家。选择一个工具(如 Cursor 或 Claude Code),深入掌握它,让它服务于你的工作流,而不是被它淹没。

理性审视:算力、能源与负责任的 AI

主持人提出了一个尖锐的问题:在区块链曾因高能耗饱受诟病之后,我们该如何理性看待 AI 巨大的算力和能源消耗?作为开发者,我们该如何权衡使用 AI 工具的成本?

嘉宾们的回答,揭示了工程优化在 AI 时代的巨大潜力:

  • Samir Ajmani (Google) 分享了一个令人振奋的实验:Go 团队尝试将 MCP 支持集成到 Go 语言服务器 (LSP) 中。结果发现,当 AI 能够直接调用精确的工具(Tools)而不是在那“空想”时,任务完成率提高了,延迟降低了,最重要的是——Token 消耗量减少了近 50%。 这意味着,通过优秀的工程工具(如 Go),我们可以显著降低 AI 的运行成本和碳排放。
  • Jaana Dogan (Google) 认为我们正处于优化的早期阶段。就像当年的数据库优化一样,模型推理 (Inference) 的效率优化将是接下来的重头戏。缓存、量化、专用硬件,这些工程手段将大幅抵消模型增长带来的成本。
  • David Suryapara (Anthropic) 提到了“小模型与蒸馏”。我们不需要每次都动用最昂贵、最慢的“超大模型”来解决所有问题。未来,针对特定领域(如代码生成)进行微调和蒸馏的小模型,将在效能和成本之间找到完美的平衡点。

不要盲目堆砌算力。“负责任的 AI”不仅是道德要求,更是工程优化的必然方向。 用更少的 Token 做更多的事,这本身就是 Go 开发者擅长的“资源优化”技能的延伸。

务实派的生存指南:过滤噪音,回归本质

在 AI 炒作的喧嚣中,如何保持清醒?

  1. 从“小”开始:不要被“AGI 即将到来”的宏大叙事吓倒。像 Katie 建议的那样,承认自己是初学者,哪怕是 MCP 的创始人也说“现在没有所谓的专家”。放下包袱,去尝试写一个简单的 Agent,去用 Go 写一个 MCP Server。
  2. 关注“确定性”:Jaana 和 Ian 都提到,AI 模型本质上是概率性的(非确定性),而工程系统需要确定性。Go 语言强大的静态分析、测试工具链和类型系统,是约束 AI 幻觉、构建可靠系统的最佳防线。用 Go 的“确定性”去包裹 AI 的“不确定性”,是未来的核心工程模式之一。
  3. 解决实际问题:不要为了 AI 而 AI。如果老板让你“加点 AI 进去”,试着去寻找那些真正能通过 AI 提升效率的痛点(比如自动化文档更新、复杂日志分析),而不是生搬硬套。

小结:Go 社区的“绿地”时刻

这场圆桌会议传递出的最强烈信号是:乐观

我们正处于一个类似于 2013 年 Docker 诞生前夜的时刻。AI 领域的“Kubernetes”、“Prometheus”还没有被写出来。这片巨大的空白,正是 Go 开发者施展拳脚的“绿地” (Greenfield)。

正如 Samir 所言:

“如果我想让 AI 真正能够与现实世界进行交易(比如订购 Pizza 并且真的送到),这中间需要大量的、可靠的基础设施。而 Go,是构建这一层的绝佳语言。”

所以,Gopher 们,别慌。带上你的并发模型,带上你的工程智慧,去构建 AI 时代的钢铁地基吧。

资料链接:https://www.youtube.com/watch?v=r40Mwdvg38M


你的 AI 实践

听了这些顶级专家的观点,你是否对 Go 在 AI 时代的未来更有信心了?在你目前的开发工作中,是否已经开始尝试用 Go 构建 AI 应用或基础设施?你认为 Go 在 AI 领域最大的短板是什么?

欢迎在评论区分享你的实战经验或困惑!让我们一起探索 Go + AI 的无限可能。

如果这篇文章为你扫除了职业焦虑,别忘了点个【赞】和【在看】,并转发给身边迷茫的 Gopher 朋友!


还在为“复制粘贴喂AI”而烦恼?我的新专栏 AI原生开发工作流实战 将带你:

  • 告别低效,重塑开发范式
  • 驾驭AI Agent(Claude Code),实现工作流自动化
  • 从“AI使用者”进化为规范驱动开发的“工作流指挥家”

扫描下方二维码,开启你的AI原生开发之旅。


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

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

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

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

目标只有一个:助你完成从“Go熟练工”到“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