Rust 1.36.0 发布,dbg! 宏现在支持多个参数

Rust 1.36.0 稳定版发布了。

如果之前已经通过 rustup 安装了 Rust,那么可以通过以下方式获取 Rust 1.36.0:

$ rustup update stable

或者直接从更新页面下载。

此版本的亮点包括:

Future 特性已稳定

有了这种稳定性,官方表示希望提供重要的 crates、库和生态系统时间来准备 async / .await

alloc crates 已稳定

在 1.36.0 之前,标准库由 std、 core和 proc_macro组成。核心包提供了核心功能,如 Iterator 和Copy ,可以在 #![no_std] 环境中使用,因为它没有强加任何要求。同时, std crate 提供类似 Box<T> 和 OS 功能的类型,但需要全局分配器和其他 OS 功能作为回报。

从 Rust 1.36.0 开始,std 的部分依赖于全局分配器,例如 Vec<T>现在可以在 alloc crate 中使用。

MaybeUninit<T> 代替 mem::uninitialized

在 Rust 的早期版本中,mem::uninitialized 函数允许通过假装已在类型 T 初始化值而不执行任何操作来绕过 Rust 的初始化检查。但是mem::uninitialized 基本上无法正确使用,因为 Rust 编译器假定值已正确初始化。

为了解决这种情况,在 Rust 1.36.0 中, MaybeUninit<T> 类型已经稳定

并且,由于 MaybeUninit<T> 是更安全的替代方案,从 Rust 1.38 开始,函数 mem::uninitialized将被弃用。

NLL 向后移植到 Rust 2015

Rust 1.31.0 推出了 NLL(非词汇生命周期),这种语言的改进使借阅检查器变得更加智能且更加用户友好。例如,可以这样写:

fn main() {
    let mut x = 5;
    let y = &x;
    let z = &mut x; // This was not allowed before 1.31.0.
}

在 1.31.0 中,NLL 仅在 Rust 2018 中稳定下来,并承诺会被向后移植到 Rust 2015。Rust 1.36.0 实现了这个承诺,NLL 现在可用于 Rust 2015。

一个新的 HashMap<K, V> 实现

在 Rust 1.36.0 中, HashMap<K, V> 实现已被替换为基于 SwissTable 设计的 hashbrown crate 中的实现。虽然接口是相同的,但 HashMap<K, V> 实现现在平均更快并且具有更低的内存开销。需要注意的是,与 hashbrown crate 不同,std 中的实现仍默认为 SipHash 1-3 散列算法。

Cargo 的离线支持

在 Rust 1.36 中,支持 --offline改变了 Cargo 的依赖性解析算法,仅使用本地缓存的依赖关系。要预先填充本地缓存以准备脱机,请使用 cargo fetch 命令,该命令将下载项目所需的所有依赖项。

库的变更

  •  dbg! 宏现在支持多个参数

新的稳定 API 包括:

  • task::Waker 和 task::Poll
  • VecDeque::rotate_left 和 VecDeque::rotate_right
  • Read::read_vectored 和 Write::write_vectored
  • Iterator::copied
  • BorrowMut<str> for String
  • str::as_mut_ptr

详情可查看发布公告

猜你喜欢

转载自www.oschina.net/news/107991/rust-1-36-0-released