diff options
author | Jordan Gong <jordan.gong@protonmail.com> | 2020-09-21 16:04:49 +0800 |
---|---|---|
committer | Jordan Gong <jordan.gong@protonmail.com> | 2020-09-21 16:04:49 +0800 |
commit | a1a8008aab6a1c70ed2a5ecde9d2f3ad21b689bf (patch) | |
tree | a734d31fab43e55fb3a1149eb43bc24f532b2950 /tree/src | |
parent | addc4ab037ed8d0635841e5ca9db3a1768c42a11 (diff) |
Use `Weak` to prevent reference cycles
Diffstat (limited to 'tree/src')
-rw-r--r-- | tree/src/main.rs | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/tree/src/main.rs b/tree/src/main.rs new file mode 100644 index 0000000..2c9f238 --- /dev/null +++ b/tree/src/main.rs @@ -0,0 +1,55 @@ +use std::cell::RefCell; +use std::rc::{Rc, Weak}; + +#[derive(Debug)] +struct Node { + value: i32, + parent: RefCell<Weak<Node>>, + children: RefCell<Vec<Rc<Node>>>, +} + +fn main() { + let leaf = Rc::new(Node { + value: 3, + parent: RefCell::new(Weak::new()), + children: RefCell::new(vec![]), + }); + + // println!("leaf parent = {:?}", leaf.parent.borrow().upgrade()); + + println!( + "leaf strong = {}, weak = {}", + Rc::strong_count(&leaf), + Rc::weak_count(&leaf), + ); + + { + let branch = Rc::new(Node { + value: 5, + parent: RefCell::new(Weak::new()), + children: RefCell::new(vec![Rc::clone(&leaf)]), + }); + + *leaf.parent.borrow_mut() = Rc::downgrade(&branch); + + println!( + "branch strong = {}, weak = {}", + Rc::strong_count(&branch), + Rc::weak_count(&branch), + ); + + println!( + "leaf strong = {}, weak = {}", + Rc::strong_count(&leaf), + Rc::weak_count(&leaf), + ); + } + + println!("leaf parent = {:?}", leaf.parent.borrow().upgrade()); + + println!( + "leaf strong = {}, weak = {}", + Rc::strong_count(&leaf), + Rc::weak_count(&leaf), + ); +} |