FromStr 特性不暴露生命周期的原因是什么?

Sla*_*nov 2 traits lifetime rust

Rust FromStr trait 是这样定义的

pub trait FromStr {
    type Err;
    fn from_str(s: &str) -> Result<Self, Self::Err>;
}
Run Code Online (Sandbox Code Playgroud)

它没有命名它的生命周期,并且不能为包含对源字符串的引用的东西实现该特征,例如:

struct MyIterator<'a> {
    cur_pointer: &'a str
}

impl<'a> FromStr for MyIterator<'a> {
    type Err = i32;
    fn from_str(s: &'a str) -> Result<Self, Self::Err> {
        Ok(MyIterator { cur_pointer: s })
    }
}
Run Code Online (Sandbox Code Playgroud)

给出错误

method `from_str` has an incompatible type for trait: expected bound lifetime parameter , found concrete lifetime [E0053]
Run Code Online (Sandbox Code Playgroud)

到目前为止,我发现没有办法为 MyIterator 实现 FromStr。我认为这是因为原始特征没有在其参数中公开字符串的生命周期。我的第一个问题是:没有办法为 MyIterator 实现 FromStr 是对的吗?如果我错了,有什么方法可以做到(假设 MyIterator 想要保留对原始字符串的引用)?

到目前为止,我只发现了这个问题:如何实现具有具体生命周期的 FromStr?,但最佳答案以“我不相信你能实现”开头,所以我想确定这在 Rust 1.0.0 中真的是不可能的。

现在,如果特征定义是这样的:

method `from_str` has an incompatible type for trait: expected bound lifetime parameter , found concrete lifetime [E0053]
Run Code Online (Sandbox Code Playgroud)

可以为包含对原始字符串的引用而不包含对原始字符串的引用的类型实现它:

trait MyFromStr<'a> {
    type Err;
    fn from_str(s: &'a str) -> Result<Self, Self::Err>;
}
Run Code Online (Sandbox Code Playgroud)

我的第二个问题是: trait FromStr 不暴露生命周期有什么特别的原因吗?也许我对生命周期有一些误解,暴露生命周期有缺点?

小智 5

包含生命周期会使特征更复杂,更具体地说,使使用该特征的通用代码更加冗长(携带不需要的生命周期)。fn foo<T: FromStr>不再起作用

对于字符串的预期用途也没有必要。通常你从一个字符串中解析并使用结果而不用担心字符串。以这种方式编码当然更容易。许多类型无论如何都不需要生命周期(请参阅实现它的类型的长列表)。

您不能FromStr为这种类型实现。你能做的是

impl<'a> From<&'a str> for MyIterator<'a> { ... }
Run Code Online (Sandbox Code Playgroud)

这为您提供了许多通用转换机制,而不是 method str::parse()。也许该方法的名称是省略生命周期的另一个论据。