将盒装特征转换为Rust中的可变特征引用

时间:2017-01-09 04:04:14

标签: rust

我在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。有什么方法可以让我的转换在可变的情况下工作吗?

1 个答案:

答案 0 :(得分:7)

我认为您正在遇到当前编译器生命周期处理的限制。作为一个函数,borrow_mut强加了比必要更严格的生命周期要求。

相反,您可以通过首先取消引用该框来对盒子的内部进行可变借用,如下所示:

fn main() {
    let mut boxed_trait: Box<MyTrait> = Box::new(MyStruct {});
    invoke_from_ref(&mut *boxed_trait);
}