Arc
Arc<T>
дозволяє спільний доступ лише для читання через Arc::clone
:
use std::sync::Arc; use std::thread; fn main() { let v = Arc::new(vec![10, 20, 30]); let mut handles = Vec::new(); for _ in 0..5 { let v = Arc::clone(&v); handles.push(thread::spawn(move || { let thread_id = thread::current().id(); println!("{thread_id:?}: {v:?}"); })); } handles.into_iter().for_each(|h| h.join().unwrap()); println!("v: {v:?}"); }
This slide should take about 5 minutes.
Arc
означає "Atomic Reference Counted", потокобезпечну версіюRc
, яка використовує атомарні операції.Arc<T>
реалізуєClone
незалежно від того, чиT
реалізує це. Він реалізуєSend
іSync
тоді і тільки тоді колиT
реалізує їх обидва.Arc::clone()
має вартість атомарних операцій, які виконуються, але після цього використанняT
є безкоштовним.- Остерігайтеся циклів посилань,
Arc
не використовує збирач сміття для їх виявлення.std::sync::Weak
може допомогти.