Struct RawOneShotRwLock

Source
pub struct RawOneShotRwLock { /* private fields */ }
Expand description

A one-shot readers-writer lock that panics instead of (dead)locking on contention.

This lock allows no contention and panics on lock_shared, lock_exclusive, lock_upgradable, and upgrade if it is already locked conflictingly. This is useful in situations where contention would be a bug, such as in single-threaded programs that would deadlock on contention.

§Examples

use one_shot_mutex::sync::OneShotRwLock;

static X: OneShotRwLock<i32> = OneShotRwLock::new(42);

// This is equivalent to `X.try_write().unwrap()`.
let x = X.write();

// This panics instead of deadlocking.
// let x2 = X.write();

// Once we unlock the mutex, we can lock it again.
drop(x);
let x = X.write();

Implementations§

Source§

impl RawOneShotRwLock

Source

pub const fn new() -> Self

Trait Implementations§

Source§

impl Default for RawOneShotRwLock

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl RawRwLock for RawOneShotRwLock

Source§

const INIT: Self

Initial value for an unlocked RwLock.
Source§

type GuardMarker = GuardSend

Marker type which determines whether a lock guard should be Send. Use one of the GuardSend or GuardNoSend helper types here.
Source§

fn lock_shared(&self)

Acquires a shared lock, blocking the current thread until it is able to do so.
Source§

fn try_lock_shared(&self) -> bool

Attempts to acquire a shared lock without blocking.
Source§

unsafe fn unlock_shared(&self)

Releases a shared lock. Read more
Source§

fn lock_exclusive(&self)

Acquires an exclusive lock, blocking the current thread until it is able to do so.
Source§

fn try_lock_exclusive(&self) -> bool

Attempts to acquire an exclusive lock without blocking.
Source§

unsafe fn unlock_exclusive(&self)

Releases an exclusive lock. Read more
Source§

fn is_locked(&self) -> bool

Checks if this RwLock is currently locked in any way.
Source§

fn is_locked_exclusive(&self) -> bool

Check if this RwLock is currently exclusively locked.
Source§

impl RawRwLockDowngrade for RawOneShotRwLock

Source§

unsafe fn downgrade(&self)

Atomically downgrades an exclusive lock into a shared lock without allowing any thread to take an exclusive lock in the meantime. Read more
Source§

impl RawRwLockRecursive for RawOneShotRwLock

Source§

fn lock_shared_recursive(&self)

Acquires a shared lock without deadlocking in case of a recursive lock.
Source§

fn try_lock_shared_recursive(&self) -> bool

Attempts to acquire a shared lock without deadlocking in case of a recursive lock.
Source§

impl RawRwLockUpgrade for RawOneShotRwLock

Source§

fn lock_upgradable(&self)

Acquires an upgradable lock, blocking the current thread until it is able to do so.
Source§

fn try_lock_upgradable(&self) -> bool

Attempts to acquire an upgradable lock without blocking.
Source§

unsafe fn unlock_upgradable(&self)

Releases an upgradable lock. Read more
Source§

unsafe fn upgrade(&self)

Upgrades an upgradable lock to an exclusive lock. Read more
Source§

unsafe fn try_upgrade(&self) -> bool

Attempts to upgrade an upgradable lock to an exclusive lock without blocking. Read more
Source§

impl RawRwLockUpgradeDowngrade for RawOneShotRwLock

Source§

unsafe fn downgrade_upgradable(&self)

Downgrades an upgradable lock to a shared lock. Read more
Source§

unsafe fn downgrade_to_upgradable(&self)

Downgrades an exclusive lock to an upgradable lock. Read more

Auto Trait Implementations§

§

impl !Freeze for RawOneShotRwLock

§

impl RefUnwindSafe for RawOneShotRwLock

§

impl Send for RawOneShotRwLock

§

impl Sync for RawOneShotRwLock

§

impl Unpin for RawOneShotRwLock

§

impl UnwindSafe for RawOneShotRwLock

Blanket Implementations§

§

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

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

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

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

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

§

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

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

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

§

fn into(self) -> U

Calls U::from(self).

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

§

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

§

type Error = Infallible

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

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

Performs the conversion.
§

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

§

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

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

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

Performs the conversion.