当前位置 : 主页 > 编程语言 > java >

【Rust日报】 2019-05-24:Rust 1.35.0 稳定版发布

来源:互联网 收集:自由互联 发布时间:2022-06-30
「找帮手」Voik: 一個類似Kafka的项目 有人做了一個實際性的project voik 讨论 Read more Rust 1.35.0 稳定版发布 概要: ​​Boxdyn Fn*​​​系列已经实现了​​Fn*​​traits 支援將閉包強制轉換

「找帮手」Voik: 一個類似Kafka的项目

有人做了一個實際性的project

  • voik
  • 讨论 Read more

Rust 1.35.0 稳定版发布

概要:

  • ​​Box<dyn Fn*>​​​系列已经实现了​​Fn*​​ traits
  • 支援將閉包強制轉換為unsafe函數指針
  • dbg!() 支擾無参数调用
  • fn main() {
    let condition = true;
    if condition {
    dbg!();
    }
    }

    得到 [src/main.rs:5]

  • 新增 copysign 給浮點數 f32 f64,這個函數可以將另一個浮點數的正負號複製給自己,但不包含數值
  • fn main() {
    assert_eq!(3.5_f32.copysign(-0.42), -3.5);
    }
  • Range 新增了下面函數
  • fn main() {
    if (0..=10).contains(&5) {
    println!("Five is included in zero to ten.");
    }
    }
    • Range::contains
    • RangeFrom::contains
    • RangeTo::contains
    • RangeInclusive::contains
    • RangeToInclusive::contains
  • RefCell 新增了函數
    • Ref::map_split
    • RefMut::map_split
    • RefCell::replace_with
  • ptr::hash 可以用指针位置 hash,而非指针裡的值
  • use std::collections::hash_map::DefaultHasher;
    use std::hash::{Hash, Hasher};
    use std::ptr;

    let five = 5;
    let five_ref = &five;

    let mut hasher = DefaultHasher::new();
    ptr::hash(five_ref, &mut hasher);
    let actual = hasher.finish();

    let mut hasher = DefaultHasher::new();
    (five_ref as *const i32).hash(&mut hasher);
    let expected = hasher.finish();

    assert_eq!(actual, expected);
  • 新增 Option::copied 來做複製 跟 Option::cloned 差不多,只是會移除 mut
  • let mut x = 12;
    let opt_x = Some(&mut x);
    assert_eq!(opt_x, Some(&mut 12));
    let copied = opt_x.copied();
    assert_eq!(copied, Some(12));

    Read more

    cargo-play

    一個好用的工具,讓你可以快速的編譯執行单个rust文件,并且可以支持第三方crate。不再需要把整個編譯项目目錄创建好

    Read more

    IntelliJ Rust 更新 #98

    支持await/async语法

    Read more

    使用Rust加速Ruby MRI

    一个使用Rust加速Ruby程序的案例,以i18n gem为示例讲述。

    Read More

    对于一些人对「Rust编写命令行应用」产生误解的说明

    【Rust日报】 2019-05-24:Rust 1.35.0 稳定版发布_高亮显示

    他说的很对,Rust近两年确实是开启了一场轰轰烈烈的命令行大替换运动。但是不是悲剧呢?

    按他的说法:Rust产出的这个命令行工具大小基本是4MB以上,性能要59ms,所以,这个太悲剧了。

    拿Rust编写的替代ls命令的exa来说,brew安装大小是1.4MB,其实也没超过2MB。9012年了,你的磁盘空间就这么不够用吗,都干啥了?运行一次的时间我没测过,但我觉得就算真的是59ms我也是可以接受的,因为在我的反应时间之外,并没有多卡。我在本地尝试用exa列出TiKV(算得上一个大型项目了)的树形列表,也没有感觉到有卡顿。所以悲剧在哪?

    软件写出来是让人用的吧?

    exa的介绍第一句话就是: You list files hundreds of times a day. Why spend your time squinting at black and white text? 你每天列出数百次文件,为什么你要花时间眯着眼睛看黑白文字?

    exa提供了很多功能,其中,高亮显示文本(区分各种元数据、文件、目录、或其他格式,比如symlinks),是大多数Rust编写的命令行工具的底线。这是Rust社区,Rust文化的体现,就是让大家感受到更好的「人体工程学」。除了高亮显示,还有很多功能,比如支持git、扩展属性等。

    所以,为什么要重写exa呢?是为了给大家节省时间,提升工作效率啊,同志们!

    同样,有很多优秀的Rust重写的命令行工具,比如ripgrep,你怎么不说说它的搜索性能呢?

    说了这么多,主要是想说明:

    用Rust重写或者新开发的命令行App,是为了让咱们这个世界更加安全、美好。这个重写,并不是盲目的。在需要安全、需要性能的地方,也不会含糊。大家都试试新工具吧。

    所以,到底什么是悲剧呢?大家想一想吧。




    日报订阅地址:

    独立日报订阅地址:

    • Telgram Channel
    • 阿里云语雀订阅
    • Steemit
    • GitHub

    社区学习交流平台订阅:

    • Rust.cc论坛: 支持rss
    • Rust Force: 支持rss
    • 微信公众号:Rust语言学习交流


    网友评论