[关闭]
@lsmn 2017-11-26T07:42:01.000000Z 字数 1026 阅读 2464

Rust 1.22将?操作符扩展到Option类型

语言 Rust macOs


摘要

为了简化Option类型的处理,最新版本的Rust允许在Option类型上使用?操作符了。此外,该版本还改进了macOS版本编译器性能和调用栈。

正文

为了简化Option类型的处理,最新版本的Rust允许在Option类型上使用?操作符了。此外,该版本还改进了macOS版本编译器性能和调用栈。

操作符是Rust 1.13为简化Result<T, E>处理而引入的。之前,开发人员可以使用模式匹配或者try!操作符处理结果:

let result = foo();
let mut result = match result {
        Ok(val) => val,
        Err(e) => return Err(e),
}

// 或者选用try!操作符
let mut result = try!(foo());

?操作符使下面这种简单许多的语法变得合法:

let mut result = foo()?;
foo()?.bar()?.baz()?

类似的,开发人员现在可以使用下面的语法

fn func_returning_option(...)
    let val = func_returning_option(...)?

代替

match func_returning_option(...) {
        None => ... ,
        Some(val) => ...
    }

该版本对Rust语言语法的另外一项扩展是允许开发人员编写下面这样的代码:

let mut x = 2;
let y = &8;

// 在Rust之前的版本中可以写成:x += *y
x += y;

该版本改进了libbacktrace库的macOS版本,提供了文件名和行号,之前只有macOS上的调用栈上没有。这是通过使用dladdr代替_NSGetExecutablePath实现的。

Rustdoc新增了compile-fail测试,亦即,如果编译器无法编译特定的语句,测试就成功。例如,开发人员现在可以定义:

/// ```compile_fail
/// let x = 5;
/// x += 2; // 不应该编译!
/// ```

Rustdoc测试是为了保证文档中测试的即时性和正确性。

在工具方面,调试编译时间得到了改进,不过,Rust团队没有提供有关这项改进的任何具体数值。

最后,Rust 1.22将许多API固化了下来。要了解详细信息,请查看发布说明

查看英文原文:Rust 1.22 Extends the ? Operator to Option Types

2or to Option Types

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注