Redian新闻
>
微软首席工程师:Rust 将面临十大挑战

微软首席工程师:Rust 将面临十大挑战

公众号新闻

推荐关注↓

来源:OSC开源社区(ID:oschina2013)

微软首席工程师 Nick Cameron 发布了一篇博客,指出了他认为现在和未来几年 Rust 将面临的十大挑战,并提出了一些初步的解决方案想法。目前,Nick Cameron 主要负责该公司 Rust 相关的工作;曾经,他还是 Rust 核心团队的成员。
Nick 指出,现如今 Rust 正处于一个良好的发展局面;受欢迎程度越来越高、贡献者越来越多,还在一些重要领域进行了应用。但在这个充满变化的时代,从一个研究项目到一个新的、快速变化的语言再过渡到一个流行的、成熟的项目,是一个困难的演变过程。
“在这里,我想描述一下我认为现在和未来几年 Rust 面临的十大挑战。我有一些解决方案的想法,但它们都是大而难的问题,没有简单的答案,所以真正的解决方案都需要迭代、精力和创造力。我的重点是核心项目;社区和生态系统面临许多挑战(例如,如何使用 Rust 制作 GUI,或者如何让更多的 crates 进入 1.0),我认为这些挑战必须主要由社区来解决。”
具体内容如下:

治理挑战

1、如何引导开发并保持 Rust 的开放性?
开源工作中,在什么是对项目最有利的,以及什么是志愿贡献者想做的之间总存在着一些矛盾。现在,随着 Rust 社区逐渐发展壮大且 Mozilla 结束直接支持,Rust 中的这种紧张关系似乎也在日益加重。尽管有很多人从事基本的维护工作,但往往人手不足;一些重要领域也缺乏资源、缺乏引导贡献的战略工作或努力。
Nick 认为,在某些方面,采用自上而下的方法可能会更容易;但此举也或将导致 Rust 失去作为开源项目所拥有的一些优势。最大的挑战是确保在完成重要但不吸引人的工作的同时,同时又不失去项目中使其令人敬畏的部分特性。Nick 表示,他们目前正在努力解决一些具体问题,包括:
  • 优先完成眼前的工作而不是开始新工作,

  • 优先考虑工具、库和非技术工作以及语言和编译器,

  • 优先考虑影响较小、成本较低的工作,这些工作总体上可能会产生很大的影响(超过大型、迷人的工作)。

与这一挑战相关的是在面对增长时保持 Rust 的基本特征。特别是,项目如何发展并接受新的贡献者和领导者(以及随之而来的不可避免的变化)而不忽视 Rust 的核心使命?随着观察者(和评论者)数量的增加,我们如何在讨论和决策中继续保持公开和透明?
2、多样性和包容性
Rust 的多样性状况很糟糕。尽管在成为一个包容性项目方面 Rust 做的可能还不错,但还是有诸多贡献者因为某些消极原因而不得不离开了该项目;避免倦怠也是包容性的一部分。
包容性的一个重要方面是能够容纳各种意见。如果我们只有在每个人都同意的情况下才能相处,那么我们就不可能多元化或包容。虽然我们对共识的偏好在某些领域对我们很有帮助,但它也带来了问题。我们避免冲突而不是解决冲突的文化是不健康的,并导致治理功能失调。这些真的很难解决!但我们必须优先解决它们,即使它们很困难,有时也很痛苦。
3、避免低效流程的僵化
Nick 称,过去的几年里在 Rust 飞速发展的同时,其流程和组织却并没有跟上步伐。在任何与治理或流程有关的事情上,都存在着巨大的变革惯性。即使现有的流程有大量的摩擦,但除了在此之上进行调整之外似乎也无可奈何。“我们已经积累了如此多的组织债务,以至于需要进行彻底的变革,但进行这种变革将是非常困难的。”
他认为,问题的核心是项目不愿意接受 “管理”(人员管理、项目管理、产品管理)作为项目领导的重要组成部分。这些事情可以独立于技术领导,但需要真正的权力委派(不仅仅是工作委派)。该项目面临的挑战是接受委托,支持这些活动,并引入更好地支持该项目的新流程。

生态系统挑战

4、Navigating the crate ecosystem
Rust 在最小标准库和 “batteries included” 之间取得了很好的平衡,原因在于其有一个繁荣的生态系统和易于使用的软件包管理器。然而,有关 crate 生态系统一直是个棘手的问题。存在很多 crates,要找到适合的则需要付出很多努力,或者说要很好地参与到社区中去。随着越来越多不是社区积极参与者用户的出现,以及 crate 数量的增加,这将成为一个更大的问题。
5、The async ecosystem
异步编程对于 Rust 目标的许多领域都很重要,且与 Rust 的编程模型配合得很好。然而,其生态系统在不同的运行时有些分裂;虽然有在进行相关的改进工作,但却进展缓慢,最终成功与否也未能确定。“风险在于我们最终会将东西带入标准库,这些东西并没有得到社区的广泛接受,我们最终会得到一个比我们开始时更糟糕的生态系统。”

技术挑战

6、如何在不失去其 core focus 的情况下使语言更具广泛吸引力?
Nick 认为 Rust 在其现有成功基础上仍有很大的增长空间。目前的很多软件都是用更侧重性能的语言编写,Rust 对安全、人体工程学和性能的关注则可以制造更好的产品并提高生产力。然而相对而言 Rust 学习难度和成本都太高,让 Rust 更容易学习和使用可能会扩大其影响力。
我不认为支持 GC、对 Rc<RefCell<T>> 类型使用含糖语法或添加一堆语法糖是解决方案。我们必须在不失去 Rust 以系统编程为核心的优势的情况下让事情变得更简单。减少对 explicit lifetimes 的需求,使 borrow checker 更强大,不要使 trait system 过于复杂,关注用户体验,避免成为一种臃肿的语言,这些都会有所帮助。也许我们会发现可以显着简化所有权和生命周期的新 abstractions?
7、内存模型和不安全代码
安全性是 Rust 主要特色之一,也是许多人使用它的动力。因此需要能够为从事不安全工作的程序员提供更多支持和更好的体验。要做到这一点,则需要对 Rust 的内存模型有更清楚的了解,然后开发语言特性、库和工具。
幸运的是,这个领域有学术研究、出色的社区工作、MIRI、不安全代码指南等等。不幸的是,这是一个非常复杂和困难的领域,许多外围人士的意见会减慢进度,并增加相关人员的工作难度。Nick 指出,出于政治和技术原因,一些可能真正影响大的更改根本无法进行。
8、发展标准库
标准库除了单调增长之外没有其他方法可以发展(可以弃用但永远不会删除,并且无法更改)。就其本身而言,这将导致标准库变得越来越庞大和混乱。但也有二阶效应:必须对稳定性采取极其保守的态度,除了 “stable forever” 和 “仅在 nightly 可用且完全可能发生变化” 之外,API 没有其他可能的状态。
相关地,标准库是一个 all or nothing deal(技术上也有 liballoc)。除了有一个更细化的版本管理解决方案外,更细化地使用标准库,而不仅仅是核心库或所有的标准库,也是有益的。
9、Big compiler changes
Rustc 现在是一个非常庞大的软件。它有很多固有的复杂性(Rust 是一种复杂的语言,在快速编译的同时提供良好的错误信息是非常困难的),很多大型软件的常见问题以及大量的技术债务。存在一些重大挑战,尤其是在编译时间方面(其中增量编译和并行编译是两种正在进行中的方法),而这些都被证明是难以实现的工作;未来想要做出重大改变只会变得更加困难。幸运的是,编译器团队有能力、精力充沛且资源充足。但是,要对 rustc 进行大的、高影响的更改仍然具有挑战性。
10、Macros
Macros 是语言中最不完善的部分之一。Declarative macros 引入了一种全新的子语言;Procedural macros 则很笨重,需要大量依赖并且难以掌握。所有的宏都与编译器(编译时间、增量编译、错误信息)和工具(IDEs、rustdoc 等的各种问题)配合得很差。
我认为这是一个巨大的挑战(而不仅仅是另一个可以处理的语言特性)的原因是,这些问题是分散的和困难的。(可能)没有良好的解决方案,只有大量的工程和设计工作。许多问题(例如,macro hygiene)需要社区中不存在的专业知识。宏的优先级也不够高(毕竟它们本质上是有效的),也没有足够的魅力来吸引贡献者。
展望
Nick 最后总结称,他列出了十个所谓 “大” 的 Rust 问题,可能会让人感觉有点消极;但这确实都是现实中所面临的挑战。幸运的是,项目内部的人都知晓这些问题的存在,并在积极地解决中。
尽管任何解决方案都很困难,但我认为所有这些挑战都有可行且现实的解决方案。如果我们能够专注于解决这些问题(当然还有其他所有的日常挑战),那么我认为 Rust 将继续发展并取得成功。
详情可查看博客全文:https://www.ncameron.org/blog/ten-challenges-for-rust/

- EOF -


加主页君微信,不仅Linux技能+1

主页君日常还会在个人微信分享Linux相关工具资源精选技术文章,不定期分享一些有意思的活动岗位内推以及如何用技术做业余项目

加个微信,打开一扇窗


推荐阅读  点击标题可跳转

1、Rust Linux 驱动程序媲美 C 驱动程序

2、Linus Torvalds:Rust 将被合并到 Linux 6.1 主线

3、Cloudflare 弃用 Nginx,改用内部 Rust 编写的 Pingora


看完本文有收获?请分享给更多人

推荐关注「Linux 爱好者」,提升Linux技能

点赞和在看就是最大的支持❤️

微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
AI仅用32张图“偷学”迪士尼插画师画风!工程师:别总拿维权说事Linux 6.1正式发布,带有MGLRU、初始Rust支持PBL的最大挑战:学生真的学到了吗?宁可少活二十年拼命拿下大油田北京量子信息科学研究院量子工程研究部招聘工程师1名(支持拓扑和二维材料团队)图灵奖得主Bengio、LeCun 等人联名发布 NeuroAI 白皮书:智能的本质是感觉运动能力,AI 迎来具身图灵测试大挑战潞晨科技实习生招聘:AIGC大模型算法工程师、AI编译器开发工程师、前端开发工程师等微软首席工程师Nick Cameron:Rust要想取得更大的成功,需要解决这十大挑战平局 | 海克斯大挑战:中国食品安全舆论场得了大病!从文字造词到网络节奏都被玩坏了AI“偷家”到迪士尼插画师了,32张图学走画风!AI工程师:这同样是创作,别总拿维权说事Bengio、LeCun 等人联名发布 NeuroAI 白皮书:智能的本质是感觉运动能力,AI 迎来具身图灵测试大挑战世界动荡,大型科学合作项目遭遇巨大挑战LeCun、Bengio等人联名发布:迈向下一代人工智能!催化NeuroAI革命!AI 迎来具身图灵测试大挑战Linus:Rust 将被合并到 Linux 6.1 主线地平线社招:感知融合方向算法工程师、SLAM/3D算法工程师麦卡锡获共和党提名当议长 更大挑战在后面…Linus Torvalds:Rust 将被合并到 Linux 6.1 主线又裁?亚马逊这次预计有1万人将丢饭碗!面对大厂裁员潮,H-1B持有者们面临巨大挑战……澜舟科技社招:算法实习生、算法开发工程师、产品实习生、资深前端开发工程师等富士康母公司鸿海:管理百万员工一直是公司最大挑战宏景智驾校招:图像算法工程师、决策规划算法工程师、SLAM建图算法工程师等台积电美国工厂:“人” 是最大挑战;中国家庭新增 13 万亿元存款,90% 是定期西方的困局和出路看看排名前十的高薪工作有哪些苹果市值一夜涨万亿元创纪录/ 华为工程师回应M7安全质疑/ 马斯克Cybertruck招生产员工…今日更多新鲜事在此新加坡卫生部长尝盐盲猜大挑战,只为了这件事...李显龙感叹:国家虽小,却面临多项巨大挑战,太脆弱了CDC警告:今年这个冬几,将面临重大挑战!极氪智能科技校招:智能驾驶规控算法工程师、智能驾驶感知算法工程师、车联网安全研究员等前红牛工程师:维斯塔潘非常有天赋,但维特尔更全面钙离子通道(Calcium Channel)与心脏病买房风波(3)“大挑战:户外疟疾媒介控制”合作研究项目审批结果公布「血月」月全食 11/8选举日高挂夜空!强力球头奖总奖金16亿!汽车制造商警告:立即停驶!涉27万辆!美面临十多年来最严重流感季Rust面临的挑战!
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。