pub struct MutexGuard<'a, T: ?Sized + 'a> { /* private fields */ }
nonpoison_mutex #134645)
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.
impl<'a, T: ?Sized> MutexGuard<'a, T>
pub fn map<U, F>(orig: Self, f: F) -> MappedMutexGuard<'a, U>where
F: FnOnce(&mut T) -> &mut U,
U: ?Sized,mapped_lock_guards #117108)
Makes a MappedMutexGuard for a component of the borrowed data, e.g. an enum variant.
The Mutex is already locked, so this cannot fail.
This is an associated function that needs to be used as MutexGuard::map(...). A method would interfere with methods of the same name on the contents of the MutexGuard used through Deref.
pub fn filter_map<U, F>(
orig: Self,
f: F,
) -> Result<MappedMutexGuard<'a, U>, Self>where
F: FnOnce(&mut T) -> Option<&mut U>,
U: ?Sized,mapped_lock_guards #117108)
Makes a MappedMutexGuard for a component of the borrowed data. The original guard is returned as an Err(...) if the closure returns None.
The Mutex is already locked, so this cannot fail.
This is an associated function that needs to be used as MutexGuard::filter_map(...). A method would interfere with methods of the same name on the contents of the MutexGuard used through Deref.
impl<T: ?Sized + Debug> Debug for MutexGuard<'_, T>
fn fmt(&self, f: &mut Formatter<'_>) -> Result
impl<T: ?Sized> Deref for MutexGuard<'_, T>
type Target = T
fn deref(&self) -> &T
impl<T: ?Sized> DerefMut for MutexGuard<'_, T>
fn deref_mut(&mut self) -> &mut T
impl<T: ?Sized + Display> Display for MutexGuard<'_, T>
fn fmt(&self, f: &mut Formatter<'_>) -> Result
impl<T: ?Sized> Drop for MutexGuard<'_, T>
impl<T: ?Sized> !Send for MutexGuard<'_, T>A MutexGuard is not Send to maximize platform portability.
On platforms that use POSIX threads (commonly referred to as pthreads) there is a requirement to release mutex locks on the same thread they were acquired. For this reason, MutexGuard must not implement Send to prevent it being dropped from another thread.
impl<T: ?Sized + Sync> Sync for MutexGuard<'_, T>T must be Sync for a MutexGuard<T> to be Sync because it is possible to get a &T from &MutexGuard (via Deref).
impl<'a, T> Freeze for MutexGuard<'a, T>where
T: ?Sized,impl<'a, T> !RefUnwindSafe for MutexGuard<'a, T>
impl<'a, T> Unpin for MutexGuard<'a, T>where
T: ?Sized,impl<'a, T> !UnwindSafe for MutexGuard<'a, T>
impl<T> Any for Twhere
T: 'static + ?Sized,impl<T> Borrow<T> for Twhere
T: ?Sized,impl<T> BorrowMut<T> for Twhere
T: ?Sized,impl<T> From<T> for T
fn from(t: T) -> T
Returns the argument unchanged.
impl<T, U> Into<U> for Twhere
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<P, T> Receiver for Pwhere
P: Deref<Target = T> + ?Sized,
T: ?Sized,type Target = T
arbitrary_self_types #44874)
impl<T> ToString for Twhere
T: Display + ?Sized,impl<T, U> TryFrom<U> for Twhere
U: Into<T>,type Error = Infallible
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
impl<T, U> TryInto<U> for Twhere
U: TryFrom<T>,
© 2010 The Rust Project Developers
Licensed under the Apache License, Version 2.0 or the MIT license, at your option.
https://doc.rust-lang.org/std/sync/nonpoison/struct.MutexGuard.html