#mutex #synchronization #lock #parking-lot #sync #locking

simple-mutex

A mutex more efficient than std and simpler than parking_lot

8 stable releases

1.1.5 May 27, 2020
1.1.4 May 26, 2020
1.1.1 May 25, 2020
1.0.1 May 23, 2020

#5 in #parking-lot

Download history 9362/week @ 2024-10-25 7441/week @ 2024-11-01 4682/week @ 2024-11-08 4659/week @ 2024-11-15 5074/week @ 2024-11-22 4560/week @ 2024-11-29 5003/week @ 2024-12-06 5415/week @ 2024-12-13 3470/week @ 2024-12-20 1979/week @ 2024-12-27 3359/week @ 2025-01-03 4667/week @ 2025-01-10 4878/week @ 2025-01-17 5313/week @ 2025-01-24 6754/week @ 2025-01-31 5280/week @ 2025-02-07

23,262 downloads per month
Used in 4 crates (2 directly)

Apache-2.0 OR MIT

14KB
170 lines

simple-mutex

Build License Cargo Documentation

A simple mutex.

More efficient than std::sync::Mutex and simpler than parking_lot::Mutex.

The locking mechanism uses eventual fairness to ensure locking will be fair on average without sacrificing performance. This is done by forcing a fair lock whenever a lock operation is starved for longer than 0.5 milliseconds.

Examples

use simple_mutex::Mutex;
use std::sync::Arc;
use std::thread;

let m = Arc::new(Mutex::new(0));
let mut threads = vec![];

for _ in 0..10 {
    let m = m.clone();
    threads.push(thread::spawn(move || {
        *m.lock() += 1;
    }));
}

for t in threads {
    t.join().unwrap();
}
assert_eq!(*m.lock(), 10);

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~140KB