Struct matrix_sdk_base::locks::MutexGuard
source · [−]pub struct MutexGuard<'a, T> where
T: ?Sized, { /* private fields */ }Expand description
A handle to a held Mutex. The guard can be held across any .await point
as it is Send.
As long as you have this guard, you have exclusive access to the underlying
T. The guard internally borrows the Mutex, so the mutex will not be
dropped while a guard exists.
The lock is automatically released whenever the guard is dropped, at which
point lock will succeed yet again.
Implementations
sourceimpl<'a, T> MutexGuard<'a, T> where
T: ?Sized,
impl<'a, T> MutexGuard<'a, T> where
T: ?Sized,
sourcepub fn map<U, F>(this: MutexGuard<'a, T>, f: F) -> MappedMutexGuard<'a, U> where
F: for<'_> FnOnce(&mut T) -> &mut U,
pub fn map<U, F>(this: MutexGuard<'a, T>, f: F) -> MappedMutexGuard<'a, U> where
F: for<'_> FnOnce(&mut T) -> &mut U,
Makes a new MappedMutexGuard for a component of the locked data.
This operation cannot fail as the MutexGuard passed in already locked the mutex.
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 locked data.
Examples
use tokio::sync::{Mutex, MutexGuard};
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
struct Foo(u32);
let foo = Mutex::new(Foo(1));
{
let mut mapped = MutexGuard::map(foo.lock().await, |f| &mut f.0);
*mapped = 2;
}
assert_eq!(Foo(2), *foo.lock().await);sourcepub fn try_map<U, F>(
this: MutexGuard<'a, T>,
f: F
) -> Result<MappedMutexGuard<'a, U>, MutexGuard<'a, T>> where
F: for<'_> FnOnce(&mut T) -> Option<&mut U>,
pub fn try_map<U, F>(
this: MutexGuard<'a, T>,
f: F
) -> Result<MappedMutexGuard<'a, U>, MutexGuard<'a, T>> where
F: for<'_> FnOnce(&mut T) -> Option<&mut U>,
Attempts to make a new MappedMutexGuard for a component of the locked data. The
original guard is returned if the closure returns None.
This operation cannot fail as the MutexGuard passed in already locked the mutex.
This is an associated function that needs to be used as MutexGuard::try_map(...). A
method would interfere with methods of the same name on the contents of the locked data.
Examples
use tokio::sync::{Mutex, MutexGuard};
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
struct Foo(u32);
let foo = Mutex::new(Foo(1));
{
let mut mapped = MutexGuard::try_map(foo.lock().await, |f| Some(&mut f.0))
.expect("should not fail");
*mapped = 2;
}
assert_eq!(Foo(2), *foo.lock().await);sourcepub fn mutex(this: &MutexGuard<'a, T>) -> &'a Mutex<T>
pub fn mutex(this: &MutexGuard<'a, T>) -> &'a Mutex<T>
Returns a reference to the original Mutex.
use tokio::sync::{Mutex, MutexGuard};
async fn unlock_and_relock<'l>(guard: MutexGuard<'l, u32>) -> MutexGuard<'l, u32> {
println!("1. contains: {:?}", *guard);
let mutex = MutexGuard::mutex(&guard);
drop(guard);
let guard = mutex.lock().await;
println!("2. contains: {:?}", *guard);
guard
}Trait Implementations
sourceimpl<'_, T> Debug for MutexGuard<'_, T> where
T: Debug + ?Sized,
impl<'_, T> Debug for MutexGuard<'_, T> where
T: Debug + ?Sized,
sourceimpl<'_, T> Deref for MutexGuard<'_, T> where
T: ?Sized,
impl<'_, T> Deref for MutexGuard<'_, T> where
T: ?Sized,
sourceimpl<'_, T> DerefMut for MutexGuard<'_, T> where
T: ?Sized,
impl<'_, T> DerefMut for MutexGuard<'_, T> where
T: ?Sized,
sourcefn deref_mut(&mut self) -> &mut <MutexGuard<'_, T> as Deref>::Target
fn deref_mut(&mut self) -> &mut <MutexGuard<'_, T> as Deref>::Target
Mutably dereferences the value.
sourceimpl<'_, T> Display for MutexGuard<'_, T> where
T: Display + ?Sized,
impl<'_, T> Display for MutexGuard<'_, T> where
T: Display + ?Sized,
sourceimpl<'_, T> Drop for MutexGuard<'_, T> where
T: ?Sized,
impl<'_, T> Drop for MutexGuard<'_, T> where
T: ?Sized,
impl<'_, T> Sync for MutexGuard<'_, T> where
T: Send + Sync + ?Sized,
Auto Trait Implementations
impl<'a, T> !RefUnwindSafe for MutexGuard<'a, T>
impl<'a, T: ?Sized> Send for MutexGuard<'a, T> where
T: Send,
impl<'a, T: ?Sized> Unpin for MutexGuard<'a, T>
impl<'a, T> !UnwindSafe for MutexGuard<'a, T>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T> WithSubscriber for T
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
Attaches the provided Subscriber to this type, returning a
WithDispatch wrapper. Read more
sourcefn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Attaches the current default Subscriber to this type, returning a
WithDispatch wrapper. Read more