rust 案例_Option 和 unwrap

上个例子展示了如何主动地引入程序失败(program failure)。当公主收到蛇这件不合适

的礼物时,我们就让程序 panic。但是,如果公主期待收到礼物,却没收到呢?这同样

是一件糟糕的事情,所以我们要想办法来解决这个问题!

我们可以检查空字符串(""),就像处理蛇那样。但既然我们在用 Rust,不如

让编译器辨别没有礼物的情况。

在标准库(std)中有个叫做 Option(option 中文意思是 “选项”)的枚举

类型,用于有 “不存在” 的可能性的情况。它表现为以下两个 “option”(选项)中

的一个:

Some(T):找到一个属于 T 类型的元素

None:找不到相应元素

这些选项可以通过 match 显式地处理,或使用 unwrap 隐式地处理。隐式处理要么

返回 Some 内部的元素,要么就 panic。

请注意,手动使用 expect 方法自定义 panic 信息是可能的,但相比显式

处理,unwrap 的输出仍显得不太有意义。在下面例子中,显式处理将举出更受控制的

结果,同时如果需要的话,仍然可以使程序 panic。

// 平民(commoner)们见多识广,收到什么礼物都能应对。

// 所有礼物都显式地使用 `match` 来处理。

fn give_commoner(gift: Option) {

// 指出每种情况下的做法。

match gift {

Some(&

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: `unwrap_or` 和 `unwrap_or_else` 都是用于从 `Result` 对象中获取值的宏。 当 `Result` 对象是 `Ok` 时,两者都会返回 `Ok` 中的值。但是当 `Result` 对象是 `Err` 时,两者的行为不同: - `unwrap_or` 将返回一个默认值。这个默认值是宏的参数,在调用 `unwrap_or` 时就已经确定了。 - `unwrap_or_else` 将调用一个闭包,并返回闭包的结果。这个闭包是宏的参数,在调用 `unwrap_or_else` 时就已经确定了。 所以,当你想要在 `Err` 时使用固定的默认值时,就可以使用 `unwrap_or`;而当你想要在 `Err` 时使用可变的值时,就可以使用 `unwrap_or_else`。 示例代码: ```rust let x: Result<i32, &str> = Err("error message"); // 使用 unwrap_or 返回默认值 let y = x.unwrap_or(0); // 使用 unwrap_or_else 返回闭包的结果 let z = x.unwrap_or_else(|| { println!("error message: {}", x.unwrap_err()); 0 }); ``` ### 回答2: 在Rust中,`unwrap_or`和`unwrap_or_else`都是处理Option类型的方法,用于在Option为None时提供一个默认值。它们之间的区别在于如何传递默认值。 对于`unwrap_or`,默认值是通过传递一个具体的值作为参数来提供的。例如,如果有一个Option类型的变量`value`,可以使用`value.unwrap_or(0)`来检查`value`的值。如果`value`是Some,则返回`value`的值;如果`value`是None,则返回传递的默认值0。 对于`unwrap_or_else`,默认值是通过传递一个闭包(函数指针)来提供的。闭包将在Option为None时被调用,并返回默认值。例如,如果有一个Option类型的变量`value`,可以使用`value.unwrap_or_else(|| 0)`来检查`value`的值。如果`value`是Some,则返回`value`的值;如果`value`是None,则调用闭包`|| 0`,返回0作为默认值。 `unwrap_or`和`unwrap_or_else`的选择取决于默认值的类型和计算成本。如果默认值是一个简单的固定值,更适合使用`unwrap_or`方法。如果默认值的计算可能比较昂贵,或者需要依赖外部状态,更适合使用`unwrap_or_else`方法,因为它提供了一种延迟计算、按需提供默认值的方式。 总之,`unwrap_or`和`unwrap_or_else`都提供了处理Option类型的方法,在Option为None时提供默认值。它们之间的区别在于如何传递默认值,`unwrap_or`传递具体值,`unwrap_or_else`传递闭包函数。 ### 回答3: `unwrap_or` 和 `unwrap_or_else` 都是 Rust 中的 Option 类型的方法,用于处理可能为 None 的值。它们的区别在于它们处理 None 值的方式。 `unwrap_or` 方法接受一个参数,表示当 Option 值是 None 时要返回的备用值。如果 Option 值是 Some,则直接返回其中的值;如果 Option 值是 None,则返回提供的备用值。 举个例子,假设有一个 Option 值为 Some(10),我们可以使用 `unwrap_or` 来获取其中的值,如果 Option 值是 None,则返回一个备用值,比如 0。代码如下: ```rust let value = Some(10); let result = value.unwrap_or(0); println!("{}", result); // 输出 10 ``` 另一方面,`unwrap_or_else` 方法接受一个闭包作为参数,当 Option 值是 None 时会调用该闭包来生成一个备用值。如果 Option 值是 Some,则直接返回其中的值。 举个例子,假设有一个 Option 值为 None,我们可以使用 `unwrap_or_else` 来生成一个备用值,比如通过闭包计算出来。代码如下: ```rust let value: Option<i32> = None; let result = value.unwrap_or_else(|| 2 + 3); println!("{}", result); // 输出 5 ``` 总的来说,使用 `unwrap_or` 可以提供一个默认的备用值,而使用 `unwrap_or_else` 可以动态生成一个备用值。因此,选择使用哪个方法取决于我们对于备用值的需求和计算方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值