微软计划使用 Rust 取代 C和C+

微软计划采用Rust作为C和C++的替代方案,以增强应用程序的安全性。据统计,过去12年间,约70%的微软补丁针对内存漏洞。Rust具有内存安全特性,能有效防止内存损坏漏洞。

 

新智元推荐

来源:InfoQ

作者:王文婧

【新智元导读】微软近日提出,未来将使用 Rust 作为 C、C++ 以及其他编程语言的替代方案,以改善应用程序的安全性的计划。

近日,微软安全响应中心(MSRC)团队在官网更新文章,就近日提出的最新计划,即未来将使用 Rust 作为 C、C++ 以及其他编程语言的替代方案以改善应用程序的安全性的计划,从空间内存安全、时间内存安全、数据竞争等方面进行了进一步的深入补充。

首席安全技术经理 Gavin Thomas 表示,开发人员的核心工作不是担心安全性,而是做好功能开发,首先需要启用一种 “不会引入内存漏洞隐患” 的开发语言。显然,这一次的主角是 Rust。

过去 12 年,约 70% 的微软补丁针对内存漏洞

如今,内存漏洞已成为黑客攻击的主要对象。据微软最新调查数据显示,在过去 12 年里,约 70% 的微软补丁都是针对内存漏洞的。

自 2004 年以来,微软安全响应中心 (MSRC) 已经对每一个报告的微软安全漏洞进行了分类。从所有的分类中,人们得出了一个令人惊讶的事实:正如 Matt Miller 今年在 BlueHat IL 的演讲中所讨论的那样,大多数修复的漏洞和分配的 CVE 都是由开发人员无意中将内存损坏错误插入到其 C 和 C++ 的代码中造成的。这两种存在内存漏洞风险的编程语言允许开发人员在代码被执行的地方对内存地址进行细粒度控制。开发人员内存管理代码中的一个错误可能导致大量内存漏洞,攻击者便可利用这些错误造成具有危险性和侵入性的后果,比如远程代码执行 (RCE) 和权限升级漏洞(EoP)。

数据来源:微软安全响应中心网站

近年来,随着微软增加其代码库并在代码中使用更多的开源软件,这一问题并没有得以解决,反而变得更糟,而微软也并不是唯一一个暴露出内存漏洞的企业。

在官网发布的最新文章中,微软安全响应中心(MSRC)团队就如何解决内存安全问题进行了如下分析,

为了解决内存安全问题,需要采取几种不同的方式。C++ 中的 “现代” 构造(例如 span)能够在一定程度上预防某些内存安全问题。此外,我们应尽可能使用其它现代 C++ 功能(例如智能指针)。

然而,现代 C++ 仍然不具备全面的内存安全与数据争用机制。更重要的是,如果程序员不加以运用,这些功能本身将毫无意义;而且这些功能在规模较大,且较为模糊的代码库可能也无法奏效。再者,C++ 缺乏能够在安全抽象当中打包不安全代码的良好工具,这意味着虽然能够在本地级别强制执行正确的编码实践,但开发人员仍很难在 C 或者 C++ 当中构建出能够安全组合的软件组件。除此之外,我们应尽可能将软件最终迁移至具备全面内存安全特性的语言当中,例如,通过运行时检查以及垃圾回收机制,实现内存保护的 C# 或者 F#。毕竟,内存管理是一项极为复杂的功能,最好是确保必要时才与其打交道。

Rust 的优势

多年来,微软始终在寻找更安全的 C 和 C++ 的替代品。2016 年 6 月,微软曾开源 “Checked C”,这是 C 语言的一个扩展,它带来了一些解决安全问题的新特性,但依然没有彻底解决问题。由于自动内存管理,Microsoft 还有其他更安全的编程语言,C#和.NET 系列是一个,编译为 JavaScript 的 TypeScript 是另一个。这些语言被 Microsoft 及其客户广泛使用,但它们无法满足所有需求。对此,微软安全响应中心(MSRC)首席安全技术经理 Gavin Thomas 表示:“如果开发人员能够将确保内存安全的 .NET,C#等语言与高效的 C ++ 结合起来,那就太好了。也许我们可以。” 因此,Rust 成为了这项计划的主角。

据了解,Rust 创建于 2006 年,被创建者 Mozilla 称为 “C / C ++ 的替代品”。最初,它只是 Mozilla 的一个研究项目,旨在开发更安全、快速的编程语言以重写 Firefox 浏览器,大多数开发人员认为它是一个理论项目,而如今 Rust 正在逐步证明自己的实力。2016 年 8 月发布的 Firefox 48 采用了以 Rust 构建的 mp4 轨道元数据解析器,该解析器首次在 Windows 和 32 位 Linux 桌面提供。最近,Brave 浏览器用 Rust 替换了最初用 C ++ 编写的广告拦截组件。Cloudflare 和 Dropbox 目前也在生产系统中运行 Rust。

Rust 的显著特征包括:

零成本抽象

移动语义

保证内存安全

没有数据竞争的线程

基于特质的泛型

模式匹配

类型推断

最小运行时间

高效的 C 绑定

Rust 团队表示,它具有丰富的系统和所有权模型,可确保内存安全和线程安全。此外,它还提供文档,包含集成的包管理器和其他有助于提高开发人员工作效率的工具。更为重要的是,Rust 从一开始就设计了防止内存损坏的漏洞。它的语法也更为简单,由它编写的应用程序不会产生相同数量的错误,因此开发人员可以专注于扩展其应用程序,而非进行持续的维护工作。

根据 StackoverFlow2019 年开发者调查报告的数据显示,Rust 是如今最受欢迎的编程语言,因此更容易招募到相关开发人员。相比之下,在这项调查中,受访者将 C 列为第四个最讨厌的编程语言,C++ 则排名第九。

StackoverFlow2019 年开发者调查报告数据

据了解,目前,除 Mozilla 之外,全球有数百家公司正在使用 Rust,如 Amazon、Atlassian、Dropbox、Facebook、Google、Microsoft、Red Hat 和 Reddit 等。在国内,百度、字节跳动、 PingCAP、蚂蚁金服、知乎、SenseTime 等企业也都在使用 Rust。

Rust 存在的问题

然而,Rust 仍存在一些不足。据先前的一项调查显示,它需要改进的方面包括:

更好的人体工程学

更好的文档

更好的库支持

更简单的学习曲线

更多的 IDE 支持

一些用户在谈及为何不使用 Rust 的原因时表示,“尽管学习曲线和语言的复杂性仍是人们学习 Rust 的阻碍,但令许多人产生共鸣的一个方面是,只是还没有足够活跃的采用 Rust 的商业项目让人们参与其中…… 对于一些人来说,只要有强烈的动机,他们就可以克服 Rust 的学习曲线。” 此外,受缺少 IDE 支持的影响,约 10% 的用户正在寻找更好的 IDE 支持,而 5% 的老用户因此停用 Rust。

对于这项或将构建新的语言生态的计划,微软安全响应中心(MSRC)首席安全技术经理 Gavin Thomas 表示,“我们是一个响应组织,但我们也发挥积极的作用 “,“我们应该从一开始就努力防止开发人员引入问题,而不是为解决问题提供指导和工具 “。目前,关于何时在其产品或云服务上使用 Rust,微软还没有具体透露。

根据2024年1月TIOBE发布的编程语言排行榜,C#由于近一年内涨幅最大(+1.43%),首次荣获年度编程语言奖。以下是2024年初编程语言使用情况及趋势分析: ### 主流编程语言使用情况 1. **Python** Python在多个领域中占据主导地位,包括数据科学、机器学习、Web开发自动化脚本编写。其语法简洁易读,拥有庞大的社区支持丰富的库资源。Python在2024年继续保持其领先地位[^1]。 2. **C#** C#在2024年表现突出,成为年度涨幅最大的编程语言。它主要用于Windows应用程序开发、游戏开发(尤其是Unity引擎)以及企业级应用开发。C#的现代化特性微软生态系统的紧密集成使其在企业应用开发中备受青睐[^1]。 3. **Java** Java仍然是企业级应用开发的首选语言之一,尤其在Android应用开发中占据重要地位。其“一次编写,到处运行”的特性使其在跨平台开发中具有优势。然而,Java的增长势头有所放缓,部分开发者转向Kotlin等新兴语言。 4. **JavaScript** JavaScript在前端开发中不可或缺,随着Node.js的发展,它也逐渐成为后端开发的重要语言。JavaScript的生态系统非常活跃,框架工具层出不穷,使其在Web开发中保持领先地位。 5. **C++** C++在系统级编程、游戏开发高性能计算领域依然占据重要地位。尽管其学习曲线较陡,但其性能优势使其在需要高效处理的应用场景中不可替代。 6. **C** C语言在嵌入式系统操作系统开发中仍然广泛使用。尽管其市场份额有所下降,但在底层开发领域依然具有不可替代的地位。 7. **Go** Go语言由Google开发,以其简洁的语法高效的并发处理能力受到欢迎。它在云计算微服务架构中表现出色,越来越多的企业开始采用Go进行后端开发。 8. **Rust** Rust以其内存安全性高性能著称,在系统编程WebAssembly开发中逐渐获得认可。Rust的社区增长迅速,越来越多的开发者将其视为C/C++的替代方案。 9. **Swift** Swift是苹果公司推出的编程语言,专为iOSmacOS应用开发设计。其现代化语法安全性特性使其在移动开发领域迅速崛起。 10. **Kotlin** Kotlin在Android开发中逐渐取代Java,成为首选语言。其与Java的互操作性简洁的语法使其在开发者中广受欢迎。 ### 编程语言的趋势分析 - **Python的持续增长**:Python在数据科学、机器学习人工智能领域的应用持续扩大,预计未来几年仍将保持领先地位。 - **C#的崛起**:C#在企业应用开发中的表现突出,尤其是在与微软云服务Azure的集成方面具有显著优势。 - **JavaScript的多样化**:JavaScript不仅在前端开发中保持主导地位,还在后端开发中通过Node.js扩展了其应用场景。 - **GoRust的崛起**:GoRust在云计算系统编程领域的应用逐渐增多,预计未来几年将迎来更广泛的应用。 - **移动开发的转型**:SwiftKotlin在移动开发领域的地位日益巩固,尤其是在苹果安卓生态系统中。 ### 代码示例 以下是一个简单的Python代码示例,展示如何使用Python进行数据分析: ```python import pandas as pd # 读取CSV文件 data = pd.read_csv('data.csv') # 显示前5行数据 print(data.head()) # 计算平均值 average = data['column_name'].mean() print(f'平均值: {average}') ``` ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值