rust废铁最快_Rust初体验,它确实有点快

写了多年的Java,某天机缘巧合之下听说了一门语言叫Rust,Rust的亲爹是Mozilla,如果要和其它语言拼爹的话,实力应该还是可以的。

官方介绍如下: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满足交换律和结合律。即a^b^a=(a^a)^b=0^b=b。

以下是撸代码环节......

Java版本:

class Solution {

public int singleNumber(int[] nums) {

int result = 0;

for (int num : nums) {

result = result ^ num;

}

return result;

}

}

LeetCode执行结果:

Rust版本:

impl Solution {

pub fn single_number(nums: Vec) -> i32 {

let mut result: i32 = 0;

for num in nums {

result = result ^ num;

}

return result;

}

}

将LeetCode运行结果整理到一个表格中,便于直观地对比:

从数据来看,Rust在执行用时和内存消耗上比Java强大太多。这个例子中内存消耗的差距更明显一些。

结语

如果不谈Java和Rust背后的生态,仅从运行效率本身来看。Rust作为一门更接近底层的语言,性能比Java强也是应该的。在内存要求苛刻、GC时间苛刻的场景下不失为一个好的选择,例如嵌入式、实时股票行情场景。能不能取代C++就看Mozilla怎么搞好社区和生态圈了,以及C++程序员们是否愿意付出学习成本。

我也是刚接触Rust,之后也会持续关注,希望Rust未来可期。朋友们有兴趣的话可以多多交流,共同拓宽技术广度与深度。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值