Struct tokio::sync::OwnedMappedMutexGuard
source · pub struct OwnedMappedMutexGuard<T: ?Sized, U: ?Sized = T> {
data: *mut U,
lock: Arc<Mutex<T>>,
}
Expand description
A owned handle to a held Mutex
that has had a function applied to it via
OwnedMutexGuard::map
.
This can be used to hold a subfield of the protected data.
Fields§
§data: *mut U
§lock: Arc<Mutex<T>>
Implementations§
source§impl<T: ?Sized, U: ?Sized> OwnedMappedMutexGuard<T, U>
impl<T: ?Sized, U: ?Sized> OwnedMappedMutexGuard<T, U>
fn skip_drop(self) -> OwnedMappedMutexGuardInner<T, U>
sourcepub fn map<S, F>(this: Self, f: F) -> OwnedMappedMutexGuard<T, S>
pub fn map<S, F>(this: Self, f: F) -> OwnedMappedMutexGuard<T, S>
Makes a new OwnedMappedMutexGuard
for a component of the locked data.
This operation cannot fail as the OwnedMappedMutexGuard
passed in already locked the mutex.
This is an associated function that needs to be used as OwnedMappedMutexGuard::map(...)
. A method
would interfere with methods of the same name on the contents of the locked data.
sourcepub fn try_map<S, F>(
this: Self,
f: F,
) -> Result<OwnedMappedMutexGuard<T, S>, Self>
pub fn try_map<S, F>( this: Self, f: F, ) -> Result<OwnedMappedMutexGuard<T, S>, Self>
Attempts to make a new OwnedMappedMutexGuard
for a component of the locked data. The
original guard is returned if the closure returns None
.
This operation cannot fail as the OwnedMutexGuard
passed in already locked the mutex.
This is an associated function that needs to be used as OwnedMutexGuard::try_map(...)
. A
method would interfere with methods of the same name on the contents of the locked data.