Arc

Arc<T> permite acesso somente-leitura compartilhado por meio de 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 1..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 significa "Atomic Reference Counted", uma versĂŁo thread-safe de Rc que usa operaçÔes atĂŽmicas.
  • Arc<T> implementa Clone quer T o faça ou nĂŁo. Ele implementa Send e Sync se e somente se T implementa os dois.
  • Arc::clone() tem o custo das operaçÔes atĂŽmicas que sĂŁo executadas, mas depois disso o uso do T Ă© gratuito.
  • Cuidado com os ciclos de referĂȘncia, Arc nĂŁo usa um coletor de lixo para detectĂĄ-los.
    • std::sync::Weak pode ajudar.