spin::rwlock

Struct RwLockUpgradableGuard

source
pub struct RwLockUpgradableGuard<'a, T: 'a + ?Sized, R = Spin> { /* private fields */ }
Expand description

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§

source§

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

source

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>

source

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

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

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

Trait Implementations§

source§

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

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

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

source§

type Target = T

The resulting type after dereferencing.
source§

fn deref(&self) -> &T

Dereferences the value.
source§

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

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

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

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

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

source§

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

Auto Trait Implementations§

§

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

§

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

§

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

§

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

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

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

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.