Rust语言的受欢迎之处
这篇由 Rust 愿景文档小组(Niko Matsakis 代表)于 2025 年 12 月 19 日发布的博客文章,深入探讨了 Rust 编程语言为何能持续获得开发者高度喜爱(如连续多年在 Stack Overflow 调查中被评为“最受喜爱/赞赏”语言),并基于广泛的用户访谈数据,分析了其核心优势、面临的挑战以及未来的发展方向。 以下是文章主要内容的详细总结:
一、 Rust 的核心魅力:赋能与多功能性
文章指出,开发者热爱 Rust 并非仅仅因为其某一项特性,而是源于多种优秀特质共同作用所带来的赋能感和多功能性。Rust 成为一个可信赖的、通用的工具,几乎可以应用于任何领域。
二、 用户欣赏 Rust 的具体方面
访谈中,用户 consistently 提到了以下几个关键优点:
-
可靠性:最常被提及的是 “如果它能编译,它就能运行” 的感觉。所有权系统和借用检查器在编译时捕获了大量潜在错误(如数据竞争、空指针),这让开发者(尤其是团队领导)对代码质量、重构安全性和让初级开发者参与关键项目更有信心。 高效性:
-
高性能:从数据中心的大规模工作负载到嵌入式设备,Rust 都能带来显著的性能提升和成本节约(文中举例有从 Python/Java 迁移到 Rust 后获得 100倍、9-10倍、4倍等性能提升)。 底层控制:为系统编程和嵌入式开发提供了类似 C 的低级控制能力,同时保证了内存安全。
-
支持性工具链:
Cargo:被广泛赞誉的包管理器和构建工具,让项目启动和依赖管理变得极其简单。 编译器错误信息:清晰、有帮助的错误提示是学习 Rust 和调试代码的关键助力。 Clippy:代码 lint 工具,帮助保持代码质量和一致性。
- 可扩展性:
语言特性:特质(Traits)、宏(Macros)等机制允许创建强大的抽象和领域特定模型。 生态系统(crates.io):丰富的第三方库(crate)生态系统,使得代码复用和快速实验变得非常容易,被誉为“最佳即拿即用的生态系统”。
三、 各要素的平衡与相互依存
文章强调,上述每个优点都是 Rust 成为多功能工具的必要条件,缺一不可:
- 失去可靠性 → 失去信任,不敢重构和部署。
- 失去高效性/底层控制 → 无法进入嵌入式、实时系统等对性能有苛刻要求的领域。
- 失去工具链和生态系统 → 入门困难,生产力低下。
当所有这些要素结合在一起时,Rust 成为了进入新领域的门户。许多受访者分享了 Rust 如何赋予他们信心,去涉足之前无法触及的领域(如从土木工程转向密码学研究,从 Java 领域转向汽车嵌入式系统),从而改变了他们的职业生涯。
四、 面临的挑战与失衡风险
然而,文章也指出,如果某些特性被过度使用或其他特性缺失,优势可能转化为障碍:
- 复杂的 API 和类型系统:
优势:类型系统可以精确建模领域逻辑,在编译时防止错误。 挑战:当同时涉及异步、泛型和生命周期时,类型可能变得极其复杂,导致代码难以理解和维护,出现了“意大利面条式类型”的说法。建议是谨慎使用复杂特性,除非确实需要。
- 异步生态系统的两难:
优势:为构建网络系统带来了巨大的性能提升。 挑战:学习曲线陡峭,被形容为需要跨越“悲伤的鸿沟”。生态系统存在碎片化(如不同运行时之间的锁定),工具链支持(如调试)不如同步 Rust 友好,一些关键语言特性(如 trait 中的 async fn)直到最近才稳定或仍有缺失。
- crates.io 生态系统的选择困境:
优势:海量的库支持是 Rust 多功能性的关键。 挑战:对新手而言,存在“选择的暴政”。缺乏明确的指南来帮助用户发现哪些库是高质量、被广泛接受且积极维护的。官方保持中立的态度有时会让初学者感到迷茫。
五、 对 Rust 未来发展的建议
基于以上分析,文章提出了三项核心建议:
- 明确并整合 Rust 的设计目标到开发流程中:
建议起草一份 RFC,正式定义 Rust 在语言、工具和库层面追求的整体体验目标(如可靠性、高效性、支持性、可扩展性等)。 借鉴“金发姑娘原则”(Goldilocks),描述每个目标“不足”、“恰到好处”和“过度”时的表现,帮助社区在设计和评估提案时保持平衡,而不是简单排序。
- 加倍投入可扩展性:
可扩展性(特质、宏等)是 Rust 多功能性的基石。建议将可扩展性从目前的类型系统和过程宏,扩展到更支持性的接口(让库能提供更好的诊断和指导信息)和编译工作流(让库能集成到编译过程的更多阶段)。 这将使 Rust 更容易使用,并支持其进入安全关键系统等需要大量自定义工具的新领域。
- 帮助用户在 Rust 生态系统中找到方向:
承认并着手解决用户在 crates.io 上选择库时面临的困难。 解决方案需要创造性,可能包括:
改善库之间的互操作性(例如,为异步等关键领域添加标准的互操作特质)。 提供标准的构建块(如 http crate 提供类型定义)。 审慎地探索如何提供更好的指导(如“入门套件”推荐),同时避免扼杀生态创新或陷入政治化。
六、 结论
Rust 的成功源于其在可靠性、高效性、支持性工具链和丰富生态系统之间取得的精妙平衡。这种平衡赋予了开发者强大的能力,去解决难题和探索新领域。 为了保持这一势头并让 Rust 持续发展,社区需要:
- 明确指导设计的原则。
- 增强语言和工具链的可扩展性。
- 帮助用户更有效地利用庞大的生态系统。
文章最后以轻松的语气提到,2025年仍有72%的 Rust 用户希望继续使用它,同时祝贺新兴语言 Gleam 也取得了接近的高满意度(70%)。
原文链接 https://blog.rust-lang.org/2025/12/19/what-do-people-love-about-rust/