【发布时间】:2020-12-30 23:44:29
【问题描述】:
我正在尝试使用内部可变性模式来共享可变引用。
但是,当我尝试使用与它共享的结构中的引用时,程序会出现以下错误:
thread 'main' panicked at 'already borrowed: BorrowMutError'
代码如下:
use std::rc::Rc;
use std::cell::RefCell;
fn main() {
let game = Game::init();
game.start();
}
struct Game {
ecs: Rc<RefCell<Ecs>>,
}
impl Game {
pub fn init() -> Game {
let ecs = Rc::new(RefCell::new(Ecs::new()));
ecs.borrow_mut().register_systems(vec![
Box::new(Renderer {
ecs: Rc::clone(&ecs),
}),
]);
Game {
ecs: Rc::clone(&ecs),
}
}
pub fn start(&self) {
self.ecs.borrow_mut().update();
}
}
struct Ecs {
systems: Vec<Box<dyn System>>,
}
impl Ecs {
fn new() -> Ecs {
Ecs {
systems: vec![],
}
}
fn register_systems(&mut self, systems: Vec<Box<dyn System>>) {
self.systems = systems;
}
fn update(&self) {
for system in self.systems.iter() {
system.update();
}
}
fn test(&self) {
println!("done!");
}
}
trait System {
fn update(&self);
}
struct Renderer {
ecs: Rc<RefCell<Ecs>>,
}
impl System for Renderer {
fn update(&self) {
self.ecs.borrow_mut().test();
}
}
问题似乎出在这条线上:
self.ecs.borrow_mut().test();
这里有什么问题?跟性格有关系吗?还是我需要以其他方式调用函数test?
【问题讨论】:
-
这条信息似乎完全正确:你
borrow_mut()两次使用相同的RefCell(通过两个不同的Rc指向它的指针),这正是你不能做的事情。
标签: rust borrow-checker borrowing