مثال

اجازه دهید Arc و Mutex را در عمل ببینیم:

use std::thread;
// use std::sync::{Arc, Mutex};

fn main() {
    let v = vec![10, 20, 30];
    let handle = thread::spawn(|| {
        v.push(10);
    });
    v.push(1000);

    handle.join().unwrap();
    println!("v: {v:?}");
}
This slide should take about 8 minutes.

راه‌حل ممکن:

use std::sync::{Arc, Mutex};
use std::thread;

fn main() {
    let v = Arc::new(Mutex::new(vec![10, 20, 30]));

    let v2 = Arc::clone(&v);
    let handle = thread::spawn(move || {
        let mut v2 = v2.lock().unwrap();
        v2.push(10);
    });

    {
        let mut v = v.lock().unwrap();
        v.push(1000);
    }

    handle.join().unwrap();

    println!("v: {v:?}");
}

بخش‌های قابل توجه:

  • v در Arc و Mutex احاطه می‌شود، زیرا مسائل آنها شبیه به هم است.
    • قرار دادن یک Mutex در یک Arc یک الگوی رایج برای به اشتراک گذاشتن حالت قابل تغییر (mutable) بین threadها است.
  • v: Arc<_> باید به عنوان v2 کلون شود تا بتوان آن را به thread دیگری منتقل کرد. نکته move به lambda signature اضافه شد.
  • بلوک‌ها برای محدود کردن دامنه LockGuard تا حد امکان معرفی شده‌اند.