Struct spin::rwlock::RwLockUpgradableGuard[][src]

pub struct RwLockUpgradableGuard<'a, T: 'a + ?Sized, R = Spin> { /* fields omitted */ }
This is supported on crate feature rwlock only.

A guard that provides immutable data access but can be upgraded to RwLockWriteGuard.

No writers or other upgradeable guards can exist while this is in scope. New reader creation is prevented (to alleviate writer starvation) but there may be existing readers when the lock is acquired.

When the guard falls out of scope it will release the lock.

Implementations

impl<'rwlock, T: ?Sized, R: RelaxStrategy> RwLockUpgradableGuard<'rwlock, T, R>[src]

pub fn upgrade(self) -> RwLockWriteGuard<'rwlock, T, R>[src]

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();

impl<'rwlock, T: ?Sized, R> RwLockUpgradableGuard<'rwlock, T, R>[src]

pub fn try_upgrade(self) -> Result<RwLockWriteGuard<'rwlock, T, R>, Self>[src]

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 */ (),
};

pub fn downgrade(self) -> RwLockReadGuard<'rwlock, T>[src]

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);

pub fn leak(this: Self) -> &'rwlock T[src]

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);

Trait Implementations

impl<'rwlock, T: ?Sized + Debug, R> Debug for RwLockUpgradableGuard<'rwlock, T, R>[src]

impl<'rwlock, T: ?Sized, R> Deref for RwLockUpgradableGuard<'rwlock, T, R>[src]

type Target = T

The resulting type after dereferencing.

impl<'rwlock, T: ?Sized + Display, R> Display for RwLockUpgradableGuard<'rwlock, T, R>[src]

impl<'rwlock, T: ?Sized, R> Drop for RwLockUpgradableGuard<'rwlock, T, R>[src]

Auto Trait Implementations

impl<'a, T, R = Spin> !RefUnwindSafe for RwLockUpgradableGuard<'a, T, R>

impl<'a, T: ?Sized, R> Send for RwLockUpgradableGuard<'a, T, R> where
    R: Send,
    T: Send + Sync

impl<'a, T: ?Sized, R> Sync for RwLockUpgradableGuard<'a, T, R> where
    R: Sync,
    T: Send + Sync

impl<'a, T: ?Sized, R> Unpin for RwLockUpgradableGuard<'a, T, R> where
    R: Unpin

impl<'a, T, R = Spin> !UnwindSafe for RwLockUpgradableGuard<'a, T, R>

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> ToString for T where
    T: Display + ?Sized
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.