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може допомогти.