Rust 发布 1.32 版本,跟踪、模块化、宏等方面均有改进

栏目: 编程语言 · Rust · 发布时间: 5年前

内容简介:Rust 1.32 提供了许多新的语言特性,用于改善开发者的程序调试体验。此外,Rust 现在默认使用系统分配器来分配内存,完成了模块化系统的相关工作,这让它变得更容易使用。新的 dbg! 宏极大简化了输出调试信息任务。例如,如果要打印变量 x 的值,现在可以使用 dbg!(x),而不是 println!(“{:#?}”,x);。另外,dbg! 还会自动打印出正在被打印的变量所在的文件和行号。dbg! 是一个会返回打印值的函数,因此可以被用在表达式中,如下所示:

Rust 1.32 提供了许多新的语言特性,用于改善开发者的程序调试体验。此外,Rust 现在默认使用系统分配器来分配内存,完成了模块化系统的相关工作,这让它变得更容易使用。

新的 dbg! 宏极大简化了输出调试信息任务。例如,如果要打印变量 x 的值,现在可以使用 dbg!(x),而不是 println!(“{:#?}”,x);。另外,dbg! 还会自动打印出正在被打印的变量所在的文件和行号。dbg! 是一个会返回打印值的函数,因此可以被用在表达式中,如下所示:

复制代码

fnfactorial(n:u32) ->u32{
ifdbg!(n <=1) {
dbg!(1)
}else{
dbg!(n * factorial(n -1))
}
}

上面的代码将输出以下内容,这样可以很容易地跟踪递归的每个执行步骤:

复制代码

[src/main.rs:3] n <=1=false
[src/main.rs:3] n <=1=false
[src/main.rs:3] n <=1=false
[src/main.rs:3] n <=1=true
[src/main.rs:4]1=1
[src/main.rs:5] n * factorial(n -1) =2
[src/main.rs:5] n * factorial(n -1) =6
[src/main.rs:5] n * factorial(n -1) =24
[src/main.rs:11] factorial(4) =24

InfoQ 之前已经报道了 Rust 1.31 引入的模块改进 ,它使模块的使用更加简单,包括更好的模块路径解析,从而简化了模块语法。Rust 1.32 更进一步,提供了统一路径,它放宽了 crate、self 或 super 必须跟在 use 声明之后的限制,从而支持非导入路径。例子如下:

复制代码

enumColor{Red,Green,Blue}

useColor::*;

Rust 1.32 还通过引入 literal 模式匹配器和使用? 改进了宏系统。例如,下面的两个宏分别定义了一个规则,当提供的节点列表分别零次或多次匹配给定模式的字面量时,将选择其中的一个规则进行展开:

复制代码

macro_rules!m1{
($lt:literal)=> {};
}

macro_rules!m2{
($(a)?) => {}
}

Rust 1.32 默认使用系统分配器分配内存,并让旧的默认分配器 jemalloc 成为可选项。在 Rust 1.28 之前,唯一可用的分配器是 jemalloc,它的起源可以追溯到 Rust 拥有自己的类 erlang 运行时时代。现在,这个运行时非常大,Rust 团队不断地将它缩减到一种极简的运行时,就像 C 语言和 C++ 等语言的运行时那样。jemalloc 是旧运行时的最后残余,它仍然占每个 Rust 二进制文件约 300KB 的空间。因此,先是在 Rust 1.28 中禁用,然后在 Rust 1.32 中作为可选项,因为它在某些情况下可以提供性能方面的优势。

如果你对 Rust 的最新特性感兴趣,请不要错过 官方发行说明

查看英文原文:

https://www.infoq.com/news/2019/01/rust-1.32-released


以上所述就是小编给大家介绍的《Rust 发布 1.32 版本,跟踪、模块化、宏等方面均有改进》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

机器学习算法原理与编程实践

机器学习算法原理与编程实践

郑捷 / 电子工业出版社 / 2015-11 / 88.00

本书是机器学习原理和算法编码实现的基础性读物,内容分为两大主线:单个算法的原理讲解和机器学习理论的发展变迁。算法除包含传统的分类、聚类、预测等常用算法之外,还新增了深度学习、贝叶斯网、隐马尔科夫模型等内容。对于每个算法,均包括提出问题、解决策略、数学推导、编码实现、结果评估几部分。数学推导力图做到由浅入深,深入浅出。结构上数学原理与程序代码一一对照,有助于降低学习门槛,加深公式的理解,起到推广和扩......一起来看看 《机器学习算法原理与编程实践》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试