我在Rust中使用动态调度指针类型时遇到了一些问题。我想将Box<MyTrait>
类型的值转换为&mut MyTrait
以传递给函数。例如,我试过:
use std::borrow::BorrowMut;
trait MyTrait {
fn say_hi(&mut self);
}
struct MyStruct { }
impl MyTrait for MyStruct {
fn say_hi(&mut self) {
println!("hi");
}
}
fn invoke_from_ref(value: &mut MyTrait) {
value.say_hi();
}
fn main() {
let mut boxed_trait: Box<MyTrait> = Box::new(MyStruct {});
invoke_from_ref(boxed_trait.borrow_mut());
}
此操作失败,并显示以下错误:
error: `boxed_trait` does not live long enough
--> <anon>:22:5
|
21 | invoke_from_ref(boxed_trait.borrow_mut());
| ----------- borrow occurs here
22 | }
| ^ `boxed_trait` dropped here while still borrowed
|
= note: values in a scope are dropped in the opposite order they are created
奇怪的是,这适用于&MyTrait
,但不适用于&mut MyTrait
。有什么方法可以让我的转换在可变的情况下工作吗?
答案 0 :(得分:7)
我认为您正在遇到当前编译器生命周期处理的限制。作为一个函数,borrow_mut
强加了比必要更严格的生命周期要求。
相反,您可以通过首先取消引用该框来对盒子的内部进行可变借用,如下所示:
fn main() {
let mut boxed_trait: Box<MyTrait> = Box::new(MyStruct {});
invoke_from_ref(&mut *boxed_trait);
}