Type Alias spin::RwLockUpgradableGuard
source · pub type RwLockUpgradableGuard<'a, T> = RwLockUpgradableGuard<'a, T>;
Expand description
A guard that provides immutable data access but can be upgraded to RwLockWriteGuard
. See
rwlock::RwLockUpgradableGuard
for documentation.
A note for advanced users: this alias exists to avoid subtle type inference errors due to the default relax strategy type parameter. If you need a non-default relax strategy, use the fully-qualified path.
Aliased Type§
struct RwLockUpgradableGuard<'a, T> { /* private fields */ }
Implementations§
source§impl<'rwlock, T: ?Sized, R: RelaxStrategy> RwLockUpgradableGuard<'rwlock, T, R>
impl<'rwlock, T: ?Sized, R: RelaxStrategy> RwLockUpgradableGuard<'rwlock, T, R>
sourcepub fn upgrade(self) -> RwLockWriteGuard<'rwlock, T, R>
pub fn upgrade(self) -> RwLockWriteGuard<'rwlock, T, R>
Upgrades an upgradeable lock guard to a writable lock guard.
let mylock = spin::RwLock::new(0);
let upgradeable = mylock.upgradeable_read(); // Readable, but not yet writable
let writable = upgradeable.upgrade();
source§impl<'rwlock, T: ?Sized, R> RwLockUpgradableGuard<'rwlock, T, R>
impl<'rwlock, T: ?Sized, R> RwLockUpgradableGuard<'rwlock, T, R>
sourcepub fn try_upgrade(self) -> Result<RwLockWriteGuard<'rwlock, T, R>, Self>
pub fn try_upgrade(self) -> Result<RwLockWriteGuard<'rwlock, T, R>, Self>
Tries to upgrade an upgradeable lock guard to a writable lock guard.
let mylock = spin::RwLock::new(0);
let upgradeable = mylock.upgradeable_read(); // Readable, but not yet writable
match upgradeable.try_upgrade() {
Ok(writable) => /* upgrade successful - use writable lock guard */ (),
Err(upgradeable) => /* upgrade unsuccessful */ (),
};
sourcepub fn downgrade(self) -> RwLockReadGuard<'rwlock, T>
pub fn downgrade(self) -> RwLockReadGuard<'rwlock, T>
Downgrades the upgradeable lock guard to a readable, shared lock guard. Cannot fail and is guaranteed not to spin.
let mylock = spin::RwLock::new(1);
let upgradeable = mylock.upgradeable_read();
assert!(mylock.try_read().is_none());
assert_eq!(*upgradeable, 1);
let readable = upgradeable.downgrade(); // This is guaranteed not to spin
assert!(mylock.try_read().is_some());
assert_eq!(*readable, 1);
sourcepub fn leak(this: Self) -> &'rwlock T
pub fn leak(this: Self) -> &'rwlock T
Leak the lock guard, yielding a reference to the underlying data.
Note that this function will permanently lock the original lock.
let mylock = spin::RwLock::new(0);
let data: &i32 = spin::RwLockUpgradableGuard::leak(mylock.upgradeable_read());
assert_eq!(*data, 0);