Struct maitake_sync::blocking::MutexGuard

source ·
pub struct MutexGuard<'a, T, Lock: RawMutex> { /* 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.

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

This structure is created by the lock and try_lock methods on Mutex.

Trait Implementations§

source§

impl<T, Lock, R: ?Sized> AsMut<R> for MutexGuard<'_, T, Lock>
where T: AsMut<R>, Lock: RawMutex,

source§

fn as_mut(&mut self) -> &mut R

Converts this type into a mutable reference of the (usually inferred) input type.
source§

impl<T, Lock, R: ?Sized> AsRef<R> for MutexGuard<'_, T, Lock>
where T: AsRef<R>, Lock: RawMutex,

source§

fn as_ref(&self) -> &R

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl<T, Lock> Debug for MutexGuard<'_, T, Lock>
where T: Debug, Lock: RawMutex,

source§

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

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

impl<T, Lock: RawMutex> Deref for MutexGuard<'_, T, Lock>

§

type Target = T

The resulting type after dereferencing.
source§

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

Dereferences the value.
source§

impl<T, Lock: RawMutex> DerefMut for MutexGuard<'_, T, Lock>

source§

fn deref_mut(&mut self) -> &mut Self::Target

Mutably dereferences the value.
source§

impl<T, Lock> Display for MutexGuard<'_, T, Lock>
where T: Display, Lock: RawMutex,

source§

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

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

impl<T, Lock> Drop for MutexGuard<'_, T, Lock>
where Lock: RawMutex,

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl<T, Lock> Send for MutexGuard<'_, T, Lock>
where T: Send, Lock: RawMutex + Sync, Lock::GuardMarker: Send,

A MutexGuard is only Send if:

  1. the protected data (T) is Send, because the guard may be used to mutably access the protected data, and can therefore be used to move it using core::mem::replace or similar.
  2. the Lock type parameter is Sync, because the guard contains a reference to the Lock type, and therefore, sending the guard is sharing a reference to the Lock.
  3. the Lock type’s RawMutex::GuardMarker associated type is Send, because this indicates that the Lock type agrees that guards may be Send.

Auto Trait Implementations§

§

impl<'a, T, Lock> Freeze for MutexGuard<'a, T, Lock>

§

impl<'a, T, Lock> RefUnwindSafe for MutexGuard<'a, T, Lock>

§

impl<'a, T, Lock> !Sync for MutexGuard<'a, T, Lock>

§

impl<'a, T, Lock> Unpin for MutexGuard<'a, T, Lock>
where <Lock as RawMutex>::GuardMarker: Unpin,

§

impl<'a, T, Lock> UnwindSafe for MutexGuard<'a, T, Lock>

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> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
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.