Rc
当需要多重所有权时,可以使用 Rc
(引用计数,Reference Counting)。Rc
会跟踪引用的数量,即包裹在 Rc
内部的值的所有者数量。
每当克隆一个 Rc
时,其引用计数就会增加 1;每当一个克隆的 Rc
离开作用域时,引用计数就会减少 1。当 Rc
的引用计数变为零(意味着没有剩余的所有者)时,Rc
及其包含的值都会被丢弃。
克隆 Rc
从不执行深拷贝。克隆只是创建另一个指向被包裹值的指针,并增加计数。
use std::rc::Rc; fn main() { let rc_examples = "Rc 示例".to_string(); { println!("--- rc_a 已创建 ---"); let rc_a: Rc<String> = Rc::new(rc_examples); println!("rc_a 的引用计数:{}", Rc::strong_count(&rc_a)); { println!("--- rc_a 被克隆为 rc_b ---"); let rc_b: Rc<String> = Rc::clone(&rc_a); println!("rc_b 的引用计数:{}", Rc::strong_count(&rc_b)); println!("rc_a 的引用计数:{}", Rc::strong_count(&rc_a)); // 两个 `Rc` 如果内部值相等,则它们相等 println!("rc_a 和 rc_b 是否相等:{}", rc_a.eq(&rc_b)); // 我们可以直接使用值的方法 println!("rc_a 内部值的长度:{}", rc_a.len()); println!("rc_b 的值:{}", rc_b); println!("--- rc_b 超出作用域被释放 ---"); } println!("rc_a 的引用计数:{}", Rc::strong_count(&rc_a)); println!("--- rc_a 超出作用域被释放 ---"); } // 错误!`rc_examples` 已经被移动到 `rc_a` 中 // 当 `rc_a` 被释放时,`rc_examples` 也会一同被释放 // println!("rc_examples: {}", rc_examples); // TODO:尝试取消注释上面这行 }