Ich möchte eine Baumdatenstruktur implementieren. Ich habe eine Node
Struktur und möchte, dass es Referenzen auf Kind Node
s hält. Ich habe versucht:Strukturdatenstruktur implementieren
use std::collections::*;
#[derive(Debug)]
struct Node {
value: String,
children: HashMap<String, Node>,
}
impl Node {
fn new(value: String) -> Self {
Node {
value: value,
children: HashMap::new(),
}
}
fn add_child(&mut self, key: String, value: String) -> &mut Node {
let mut node = Node::new(value);
self.children.insert(key, node);
&mut node
}
}
fn main() {
let mut root_node = Node::new("root".to_string());
root_node.add_child("child_1_1".to_string(), "child_1_1_value".to_string());
}
Dieser Code nicht kompiliert:
error: `node` does not live long enough
--> src/main.rs:22:10
|
22 | &mut node
| ^^^^ does not live long enough
23 | }
| - borrowed value only lives until here
|
note: borrowed value must be valid for the anonymous lifetime #1 defined on the body at 19:67...
--> src/main.rs:19:68
|
19 | fn add_child(&mut self, key: String, value: String) -> &mut Node {
| ____________________________________________________________________^ starting here...
20 | | let mut node = Node::new(value);
21 | | self.children.insert(key, node);
22 | | &mut node
23 | | }
| |___^ ...ending here
error[E0382]: use of moved value: `node`
--> src/main.rs:22:10
|
21 | self.children.insert(key, node);
| ---- value moved here
22 | &mut node
| ^^^^ value used here after move
|
= note: move occurs because `node` has type `Node`, which does not implement the `Copy` trait
Wie kann ich das umsetzen?
Wahrscheinlich Duplikat [Gibt es eine Möglichkeit einen Verweis auf eine Variable in einer Funktion erstellt zurückzukehren? ] (http://stackoverflow.com/q/32682876/155423) – Shepmaster
@Shempmaster Wahrscheinlich nicht. Es gibt mehrere Probleme, aber OP möchte den neu erstellten Wert in eine Hash-Map einfügen und einen Verweis auf den Wert innerhalb der Hash-Map zurückgeben (siehe den zweiten Fehler, der in diesem Fall wichtiger ist). –