Мне нужно сопоставить необязательное значение, которое находится в self, из метода, и на основе этого совпадения вызвать метод в self, который принимает self изменяемым образом. Я пытаюсь сделать довольно высокопроизводительную игру, поэтому, как бы я ни хотел обойтись без изменчивости, я не могу в этой ситуации: методы действительно нуждаются в изменяемом доступе к структуре, и им действительно нужно для отправки на основе свойств структур. Вот MVCE:
enum Baz {
A,
B,
C,
}
struct Foo {
bar: Option<Baz>,
}
impl Foo {
pub fn dostuff(&mut self, fizz: i32) {
if let Some(ref b) = self.bar {
match b {
&Baz::A => self.do_a(fizz),
&Baz::B => self.do_b(fizz + 2),
&Baz::C => self.do_c(fizz + 1),
}
}
}
pub fn do_a(&mut self, f: i32) {
println!("A, with fizz {}", f);
}
pub fn do_b(&mut self, f: i32) {
println!("B, with fizz {}", f);
}
pub fn do_c(&mut self, f: i32) {
println!("C, with fizz {}", f);
}
}
fn main() {
let foo = Foo { bar: Some(Baz::A) };
foo.dostuff(3);
}
А вот и игровая площадка.
error[E0502]: cannot borrow `*self` as mutable because `self.bar.0` is also borrowed as immutable
--> src/main.rs:14:28
|
12 | if let Some(ref b) = self.bar {
| ----- immutable borrow occurs here
13 | match b {
14 | &Baz::A => self.do_a(fizz),
| ^^^^ mutable borrow occurs here
...
18 | }
| - immutable borrow ends here
Я думал, что примирился с проверкой заимствования, но, видимо, нет: я понятия не имею, как это исправить, хотя я знаю, почему это происходит. Буду признателен, если кто-нибудь объяснит, как избежать этого в будущем.
do_a/do_b/do_cизменилиself.b, это нарушило бы правила безопасности памяти Rust, потому что изменилась бы неизменяемая ссылка. - person Shepmaster   schedule 09.08.2017