Rust初体验
写了多年的Java,某天机缘巧合之下听说了一门语言叫Rust,Rust的亲爹是Mozila,如果要和其它语言拼爹的话,实力应该还是可以的。
官方介绍如下:
Rust is blazingly fast and memory-efficient: with no runtime or garbage collector, it can power performance-critical services, run on embedded devices, and easily integrate with other languages.
Rust速度快得惊人,内存效率也很高。没有运行时或垃圾收集器,它可以为性能关键的服务提供强大支持,可以在嵌入式设备上运行,并且很容易与其他语言集成。
Rust’s rich type system and ownership model guarantee memory-safety and thread-safety — enabling you to eliminate many classes of bugs at compile-time.
Rust丰富的类型系统和所有权模型保证了内存安全性和线程安全性——使您能够在编译时消除许多各种各样的bug。
Rust has great documentation, a friendly compiler with useful error messages, and top-notch tooling — an integrated package manager and build tool, smart multi-editor support with auto-completion and type inspections, an auto-formatter, and more.
Rust的文档很强大,有一个友好的编译器,能提示一些有用的错误信息,以及一流的工具——一个集成的包管理器和构建工具,支持自动完成和类型检查的智能多项编辑器,一个自动格式化程序,等等。
我已经在上文中把今天的重点加粗标识了。打算用一个LeetCode上的算法题目来对比下Java实现和Rust实现,看看Rust是不是真的很惊人。
题目如下:
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
欢迎留言讨论。微信/知乎可搜索码神手记同名账号,分享关注,共同进步。
示例1:
输入: [2,2,1]
输出: 1
示例2
输入: [4,1,2,1,2]
输出: 4
解法:利用异或运算(XOR)的特性,使用位操作进行计算。
先来一起复习下XOR的特性:
- 对0和任意数进行XOR运算,得到的仍然是这个数本身,即a^0=a。
- 对同一个数进行XOR运算,返回的结果是0。即a^a=0。
- XOR满足交换律和结合律。即aba=(aa)b=0^b=b。
以下是撸代码环节......
Java版本:
class Solution {
public int singleNumber(int[] nums) {
int result = 0;
for (int num : nums) {
result = result ^ num;
}
return result;
}
}
Rust版本:
impl Solution {
pub fn single_number(nums: Vec<i32>) -> i32 {
let mut result: i32 = 0;
for num in nums {
result = result ^ num;
}
return result;
}
}
执行结果整理到一个表格中,便于直观地对比:
语言 | 执行用时 | 内存消耗 |
---|---|---|
Java | 1ms | 40.9MB |
Rust | 0ms | 2.1MB |
从数据来看,Rust在执行用时和内存消耗上比Java强大太多。这个例子中内存消耗的差距更明显一些。
结语
如果不谈Java和Rust背后的生态,仅从运行效率本身来看。Rust作为一门更接近底层的语言,性能比Java强也是应该的。在内存要求苛刻、GC时间苛刻的场景下不失为一个好的选择,例如嵌入式、实时股票行情场景。能不能取代C++就看Mozila怎么搞好社区和生态圈了,以及C++程序员们是否愿意付出学习成本。
我也是刚接触Rust,之后也会持续关注,希望Rust未来可期。朋友们有兴趣的话可以多多交流,共同拓宽技术广度与深度。
欢迎留言讨论。微信/知乎可搜索码神手记同名账号,分享关注,共同进步。
网友评论