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