Trait std::convert::TryFrom 1.34.0[−][src]
Expand description
简单安全的类型转换在某些情况下可能会以受控方式失败。它是 TryInto
的倒数。
当您进行的类型转换可能会成功完成但可能还需要特殊处理时,这很有用。
例如,无法使用 From
trait 将 i64
转换为 i32
,因为 i64
可能包含 i32
无法表示的值,因此转换将丢失数据。
这可以通过将 i64
截断为 i32
(本质上给 i64
的值取 i32::MAX
模) 或通过简单地返回 i32::MAX
或其他方法来处理。
From
trait 用于完美的转换,因此 TryFrom
trait 会通知程序员类型转换何时会变差,并让他们决定如何处理它。
泛型实现
TryFrom<T> for U
意味着TryInto
<U> for T
try_from
是反射的,这意味着TryFrom<T> for T
已实现并且不会失败 – 用于在类型T
上调用T::try_from()
的关联Error
类型是Infallible
。 当!
类型稳定后,Infallible
和!
将等效。
TryFrom<T>
可以实现如下:
use std::convert::TryFrom;
struct GreaterThanZero(i32);
impl TryFrom<i32> for GreaterThanZero {
type Error = &'static str;
fn try_from(value: i32) -> Result<Self, Self::Error> {
if value <= 0 {
Err("GreaterThanZero only accepts value superior than zero!")
} else {
Ok(GreaterThanZero(value))
}
}
}
RunExamples
use std::convert::TryFrom;
let big_number = 1_000_000_000_000i64;
// 默默地截断 `big_number`,事实之后需要检测并处理该截断。
let smaller_number = big_number as i32;
assert_eq!(smaller_number, -727379968);
// 由于 `big_number` 太大而无法容纳在 `i32` 中,因此返回错误。
let try_smaller_number = i32::try_from(big_number);
assert!(try_smaller_number.is_err());
// 返回 `Ok(3)`。
let try_successful_smaller_number = i32::try_from(3);
assert!(try_successful_smaller_number.is_ok());
RunAssociated Types
Required methods
Implementors
将 U+0000..=U+00FF 中代码点的 char
映射到 0x00..=0xFF 中具有相同值的字节,如果代码点大于 U+00FF 则失败。
有关编码的详细信息,请参见 impl From<u8> for char
。