Приклад
Давайте подивимося на 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є загальним шаблоном для обміну змінним станом між потоками.
- Обгортання
v: Arc<_>потрібно клонувати якv2, перш ніж це можна буде перемістити в інший потік. Зверніть увагу, що до сигнатури лямбда було доданоmove.- Блоки вводяться для того, щоб максимально звузити область використання
LockGuard.