
微软 TypeScript 团队发布TypeScript 编译器(tsc)的实验性原生版本 tsc-go,旨在将构建时间缩短 10 倍,大幅减少编辑器冷启动时间,并显著改善内存使用情况。这一举措旨在探索在没有 Node.js 运行时开销的情况下运行编译器(用 Go 语言编写)。
TypeScript 项目首席架构师Anders Hejlsberg解释了开发原生版本的动机:
TypeScript 的核心价值主张是卓越的开发体验。随着代码库的增长,[...]在许多情况下,TypeScript 代码库没法扩展得很大。从事大型项目的开发人员[...]必须在合理的编辑器启动时间和获得完整的源代码视图之间做出选择[...]由 AI 驱动的新体验需要使用大量的语义信息窗口,因为有更严格的延迟约束。同时我们也希望,快捷的命令行构建可以验证你的整个代码库是否处于良好的状态。
在 Node.js 上运行的标准 tsc 编译器,在初始执行时会产生明显的启动时间,尤其是在大型项目或频繁的小构建中。这个新的实验性 TypeScript 编译器是用 Go 编写的,并编译成原生代码,无需 Node.js 启动开销即可运行。
博客公告提到,VS Code1 MLOC 代码库的类型检查时间从 77 秒减少到了 7.5 秒,即 10 倍的改进。他们在 Playwright 代码库(356000 LOC)上也观察到了相同的降幅,时间从 11 秒减少到了 1 秒。微软还报告说,在比较小的代码库上也是如此,RxJS(2100 LOC)的类型检查时间从 1.1 秒减少到了 0.1 秒。博客文章没有提供与增量构建相关的改进数据。
TypeScript 团队还报告说,在 Visual Studio 代码库的编辑器场景中,项目加载时间减少了 8 倍,并且说,这一比例在其他代码库上预计也将保持不变。开发体验有望得到改善,因为打开代码编辑器和完全加载代码库准备好输入之间的时间显著缩短。
这个原生版本(代号 Corsa)仍被视为实验性的,还缺少许多功能,包括增量构建(参见迄今为止的工作)。博客公告解释说,当原生代码库与当前的 TypeScript 达到足够的一致性时,它将作为 TypeScript 7.0 发布,并为以前的版本提供便捷的迁移路径:
我们还会继续维护 6.x 系列的 JS 代码库,直到 TypeScript 7+达到足够的成熟度和采用度。
在Reddit和Hacker News等平台上,开发者询问选择 Go 而不是 Rust 的理由。TypeScript 开发负责人Ryan Cavanaugh提供了一个详细的答案,并邀请开发者查看。下面是其中的一段:
归根结底,我们有两个选择——用 Rust 从头开始完全重写,这可能需要数年时间,并产生一个不兼容的 TypeScript 版本,没有人会实际使用,或者只是用 Go 进行移植,并在一年左右的时间里得到一些可用的东西,并且在语义上高度兼容,在性能上极具竞争力。
除了博客文章外,感兴趣的开发人员可以看下 Hejlsberg 在 YouTube 上介绍 TypeScript 当前移植工作的视频。开发人员还可以访问GitHub仓库,了解 TypeScript 原生移植的开发情况。npm 上提供了预览构建 @typescript/native-preview。VS Code 市场上提供了预览版VS Code扩展。
该项目在 Apache License 2.0 协议下发布,并欢迎贡献和建议,详情请参阅贡献者许可协议。该项目遵循微软开源行为准则。要了解更多信息,请参阅行为准则FAQ。
声明:本文为 InfoQ 翻译,未经许可禁止转载。
原文链接:https://www.infoq.com/news/2025/05/new-typescript-compiler-10x-fast/
评论