Struct futures::lock::MutexGuard [−][src]
pub struct MutexGuard<'a, T> where
T: ?Sized, { /* fields omitted */ }
An RAII guard returned by the lock
and try_lock
methods.
When this structure is dropped (falls out of scope), the lock will be
unlocked.
Implementations
impl<'a, T> MutexGuard<'a, T> where
T: ?Sized,
[src]
impl<'a, T> MutexGuard<'a, T> where
T: ?Sized,
[src]pub fn map<U, F>(this: MutexGuard<'a, T>, f: F) -> MappedMutexGuard<'a, T, U> where
F: FnOnce(&mut T) -> &mut U,
U: ?Sized,
[src]
F: FnOnce(&mut T) -> &mut U,
U: ?Sized,
Returns a locked view over a portion of the locked data.
Example
use futures::lock::{Mutex, MutexGuard}; let data = Mutex::new(Some("value".to_string())); { let locked_str = MutexGuard::map(data.lock().await, |opt| opt.as_mut().unwrap()); assert_eq!(&*locked_str, "value"); }
Trait Implementations
impl<'_, T> Debug for MutexGuard<'_, T> where
T: Debug + ?Sized,
[src]
impl<'_, T> Debug for MutexGuard<'_, T> where
T: Debug + ?Sized,
[src]impl<'_, T> Deref for MutexGuard<'_, T> where
T: ?Sized,
[src]
impl<'_, T> Deref for MutexGuard<'_, T> where
T: ?Sized,
[src]impl<'_, T> DerefMut for MutexGuard<'_, T> where
T: ?Sized,
[src]
impl<'_, T> DerefMut for MutexGuard<'_, T> where
T: ?Sized,
[src]impl<'_, T> Send for MutexGuard<'_, T> where
T: Send + ?Sized,
[src]
T: Send + ?Sized,
impl<'_, T> Sync for MutexGuard<'_, T> where
T: Sync + ?Sized,
[src]
T: Sync + ?Sized,