Struct guardian::ArcMutexGuardian

source ·
pub struct ArcMutexGuardian<T: 'static> { /* private fields */ }
Expand description

An RAII implementation of a “scoped lock” of a mutex. When this structure is dropped (falls out of scope), the lock will be unlocked. Keeps a handle to an Arc so that the lock is not dropped until the guard is.

The data protected by the mutex can be access through this guard via its Deref and DerefMut implementations.

Implementations§

source§

impl<T> ArcMutexGuardian<T>

source

pub fn take(handle: Arc<Mutex<T>>) -> LockResult<ArcMutexGuardian<T>>

Acquires a mutex, blocking the current thread until it is able to do so.

This function will block the local thread until it is available to acquire the mutex. Upon returning, the thread is the only thread with the mutex held. An RAII guardian is returned to allow scoped unlock of the lock. When the guard goes out of scope, the mutex will be unlocked. The guardian also holds a strong reference to the lock’s Arc, which is dropped when the guard is.

§Errors

If another user of this mutex panicked while holding the mutex, then this call will return an error once the mutex is acquired.

source

pub fn try_take( handle: Arc<Mutex<T>>, ) -> Option<LockResult<ArcMutexGuardian<T>>>

Attempts to acquire this lock.

If the lock could not be acquired at this time, then None is returned. Otherwise, an RAII guard is returned. The lock will be unlocked when the guard is dropped. The guardian also holds a strong reference to the lock’s Arc, which is dropped when the guard is.

This function does not block.

Trait Implementations§

source§

impl<T> Deref for ArcMutexGuardian<T>

§

type Target = T

The resulting type after dereferencing.
source§

fn deref(&self) -> &Self::Target

Dereferences the value.
source§

impl<T> DerefMut for ArcMutexGuardian<T>

source§

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

Mutably dereferences the value.
source§

impl<T> Drop for ArcMutexGuardian<T>

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl<T> From<Arc<Mutex<T>>> for ArcMutexGuardian<T>

source§

fn from(handle: Arc<Mutex<T>>) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

§

impl<T> Freeze for ArcMutexGuardian<T>

§

impl<T> RefUnwindSafe for ArcMutexGuardian<T>

§

impl<T> !Send for ArcMutexGuardian<T>

§

impl<T> Sync for ArcMutexGuardian<T>
where T: Send + Sync,

§

impl<T> Unpin for ArcMutexGuardian<T>

§

impl<T> UnwindSafe for ArcMutexGuardian<T>

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>,

§

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>,

§

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.