pub struct OwnedRwLockReadGuard<T: ?Sized, U: ?Sized = T> { /* private fields */ }Expand description
Owned RAII structure used to release the shared read access of a lock when dropped.
This structure is created by the read_owned method on
RwLock.
Implementations§
Source§impl<T: ?Sized, U: ?Sized> OwnedRwLockReadGuard<T, U>
impl<T: ?Sized, U: ?Sized> OwnedRwLockReadGuard<T, U>
Sourcepub fn map<F, V: ?Sized>(this: Self, f: F) -> OwnedRwLockReadGuard<T, V>
pub fn map<F, V: ?Sized>(this: Self, f: F) -> OwnedRwLockReadGuard<T, V>
Makes a new OwnedRwLockReadGuard for a component of the locked data.
This operation cannot fail as the OwnedRwLockReadGuard passed in
already locked the data.
This is an associated function that needs to be
used as OwnedRwLockReadGuard::map(...). A method would interfere with
methods of the same name on the contents of the locked data.
§Examples
use std::sync::Arc;
use tokio::sync::{RwLock, OwnedRwLockReadGuard};
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
struct Foo(u32);
let lock = Arc::new(RwLock::new(Foo(1)));
let guard = lock.read_owned().await;
let guard = OwnedRwLockReadGuard::map(guard, |f| &f.0);
assert_eq!(1, *guard);Sourcepub fn try_map<F, V: ?Sized>(
this: Self,
f: F,
) -> Result<OwnedRwLockReadGuard<T, V>, Self>
pub fn try_map<F, V: ?Sized>( this: Self, f: F, ) -> Result<OwnedRwLockReadGuard<T, V>, Self>
Attempts to make a new OwnedRwLockReadGuard for a component of the
locked data. The original guard is returned if the closure returns
None.
This operation cannot fail as the OwnedRwLockReadGuard passed in
already locked the data.
This is an associated function that needs to be used as
OwnedRwLockReadGuard::try_map(..). A method would interfere with
methods of the same name on the contents of the locked data.
§Examples
use std::sync::Arc;
use tokio::sync::{RwLock, OwnedRwLockReadGuard};
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
struct Foo(u32);
let lock = Arc::new(RwLock::new(Foo(1)));
let guard = lock.read_owned().await;
let guard = OwnedRwLockReadGuard::try_map(guard, |f| Some(&f.0)).expect("should not fail");
assert_eq!(1, *guard);Sourcepub fn rwlock(this: &Self) -> &Arc<RwLock<T>>
pub fn rwlock(this: &Self) -> &Arc<RwLock<T>>
Returns a reference to the original Arc<RwLock>.
§Examples
use std::sync::Arc;
use tokio::sync::{RwLock, OwnedRwLockReadGuard};
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
struct Foo(u32);
let lock = Arc::new(RwLock::new(Foo(1)));
let guard = lock.clone().read_owned().await;
assert!(Arc::ptr_eq(&lock, OwnedRwLockReadGuard::rwlock(&guard)));
let guard = OwnedRwLockReadGuard::map(guard, |f| &f.0);
assert!(Arc::ptr_eq(&lock, OwnedRwLockReadGuard::rwlock(&guard)));