commit | 514f22cf05da96bdf709678e74bcabdf174ff65a | [log] [tgz] |
---|---|---|
author | James Farrell <[email protected]> | Fri Sep 20 17:29:11 2024 +0000 |
committer | Automerger Merge Worker <[email protected]> | Fri Sep 20 17:29:11 2024 +0000 |
tree | bd7116c534d29fd5c9137e2ee96c318b196f9131 | |
parent | 689215b36e63a9f2357ff819299e0bcbd1afff3b [diff] | |
parent | a49aba6865503d0ae4dd4064135190b80fd2e977 [diff] |
Migrate 26 crates to monorepo am: e3a74b5a3c am: a49aba6865 Original change: https://android-review.googlesource.com/c/platform/external/rust/crates/try-lock/+/3272314 Change-Id: Ifdc52a238e3d080e897fc7655a5ec51538fbe38a Signed-off-by: Automerger Merge Worker <[email protected]>
A light-weight lock guarded by an atomic boolean.
Most efficient when contention is low, acquiring the lock is a single atomic swap, and releasing it just 1 more atomic swap.
use std::sync::Arc; use try_lock::TryLock; // a thing we want to share struct Widget { name: String, } // lock it up! let widget1 = Arc::new(TryLock::new(Widget { name: "Spanner".into(), })); let widget2 = widget1.clone(); // mutate the widget let mut locked = widget1.try_lock().expect("example isn't locked yet"); locked.name.push_str(" Bundle"); // hands off, buddy let not_locked = widget2.try_lock(); assert!(not_locked.is_none(), "widget1 has the lock"); // ok, you can have it drop(locked); let locked2 = widget2.try_lock().expect("widget1 lock is released"); assert_eq!(locked2.name, "Spanner Bundle");