[英]cannot infer an appropriate lifetime for borrow expression due to conflicting requirements
pub struct FooStruct<'a> {
pub bars: Vec<&'a str>,
}
pub trait FooTrait<'a> {
fn getBars(&self) -> &'a Vec<&'a str>;
}
impl<'a> FooTrait<'a> for FooStruct<'a> {
fn getBars(&self) -> &'a Vec<&'a str> {
&self.bars // cannot infer an appropriate lifetime for borrow expression due to conflicting requirements
}
}
我不明白需求冲突来自哪里。 Afaik 没有冲突,因为只要FooStruct
存在,一切都会存在。
让我们把它拆开:
pub struct FooStruct<'a> {
pub bars: Vec<&'a str>,
}
FooStruct
包含一个容器,其中包含生命周期'a
的字符串切片。 容器的生命周期对应于FooStruct
的生命周期。
pub trait FooTrait<'a> {
fn getBars(&self) -> &'a Vec<&'a str>;
}
FooTrait
希望getBars
返回对包含生命周期'a
字符串切片的容器的引用。 返回的引用的生命周期也应该是'a
。
impl<'a> FooTrait<'a> for FooStruct<'a> {
fn getBars(&self) -> &'a Vec<&'a str> {
&self.bars
}
}
在这里, getBars
返回对self.bars
的引用,它是一个包含生命周期'a
的字符串切片的容器。 到目前为止,一切都很好。
&self.bars
的生命周期是多少? 它对应于self
的生命周期(即各自的FooStruct
)。self
的寿命是多少? 它是'self
(隐含的生命周期)。 但是, FooTrait
要求返回的引用生命周期为'a
,因此与FooTrait
的声明不匹配。
一种解决方案是在FooTrait
中分离生命周期:
pub trait FooTrait<'a> {
fn getBars<'s>(&'s self) -> &'s Vec<&'a str>;
}
impl<'a> FooTrait<'a> for FooStruct<'a> {
fn getBars<'s>(&'s self) -> &'s Vec<&'a str> {
&self.bars
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.