[英]Why does a reference to a trait in a generic function have to implement `Sized`?
我有一个返回对特征的引用的函数( trait_ref()
),以及另一个对通用特征实现的引用的函数( take_trait_ref_generic
)。
但是,不可能将我从第一个函数获得的引用传递给第二个函数。 Rustc抱怨说“特质std::marker::Sized
没有为SomeTrait
实现”。
即使是这样,为什么还要实施Sized
? 无论如何,这都是参考。
trait SomeTrait {}
struct TraitImpl;
impl SomeTrait for TraitImpl {}
struct Container {
trait_impl: TraitImpl,
}
impl Container {
fn trait_ref(&self) -> &SomeTrait {
&self.trait_impl
}
}
fn take_trait_ref_generic<T: SomeTrait>(generic_trait_ref: &T) {}
fn main() {
let container = Container { trait_impl: TraitImpl };
/*Not possible*/
take_trait_ref_generic(container.trait_ref());
}
默认情况下, 无论如何使用,函数上的所有通用类型都隐式具有Sized
限制。 您需要使用?Sized
明确退出该要求:
fn take_trait_ref_generic<T>(generic_trait_ref: &T)
where
T: ?Sized + SomeTrait
{}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.