Mutex

Mutex<T>๋ฅผ ์ด์šฉํ•˜๋ฉด ๋ถˆ๋ณ€ ์ฐธ์กฐ๋ฅผ ํ†ตํ•ด์„œ๋„ T์˜ ๊ฐ’์„ ์ˆ˜์ •ํ•  ์ˆ˜๊ฐ€ ์žˆ์œผ๋ฉฐ, ์ด์— ๋”ํ•ด์„œ ํ•œ ๋ฒˆ์— ํ•œ ์Šค๋ ˆ๋“œ๋งŒ T์˜ ๊ฐ’์„ ์ ‘๊ทผ(์ฝ๊ฑฐ๋‚˜ ์“ฐ๊ฑฐ๋‚˜)ํ•จ์„ ๋ณด์žฅํ•ด ์ค๋‹ˆ๋‹ค:

use std::sync::Mutex;

fn main() {
    let v = Mutex::new(vec![10, 20, 30]);
    println!("v: {:?}", v.lock().unwrap());

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

    println!("v: {:?}", v.lock().unwrap());
}

๋ชจ๋“  Mutex<T>๋Š” impl<T: Send> Sync for Mutex<T>๋ฅผ ์ž๋™์œผ๋กœ ๊ตฌํ˜„ํ•จ์„ ์ฐธ์กฐํ•˜์„ธ์š”.

  • Mutex in Rust looks like a collection with just one element - the protected data.
    • It is not possible to forget to acquire the mutex before accessing the protected data.
  • You can get an &mut T from an &Mutex<T> by taking the lock. The MutexGuard ensures that the &mut T doesnโ€™t outlive the lock being held.
  • Mutex<T> implements both Send and Sync iff (if and only if) T implements Send.
  • A read-write lock counterpart - RwLock.
  • Why does lock() return a Result?
    • If the thread that held the Mutex panicked, the Mutex becomes โ€œpoisonedโ€ to signal that the data it protected might be in an inconsistent state. Calling lock() on a poisoned mutex fails with a PoisonError. You can call into_inner() on the error to recover the data regardless.