Struct OwnedRwLockWriteGuard
pub struct OwnedRwLockWriteGuard<T>where
T: ?Sized,{ /* private fields */ }
dep_tokio
and std
only.Expand description
Owned RAII structure used to release the exclusive write access of a lock when dropped.
This structure is created by the write_owned
method
on RwLock
.
Implementations§
§impl<T> OwnedRwLockWriteGuard<T>where
T: ?Sized,
impl<T> OwnedRwLockWriteGuard<T>where
T: ?Sized,
pub fn map<F, U>(
this: OwnedRwLockWriteGuard<T>,
f: F,
) -> OwnedRwLockMappedWriteGuard<T, U>
pub fn map<F, U>( this: OwnedRwLockWriteGuard<T>, f: F, ) -> OwnedRwLockMappedWriteGuard<T, U>
Makes a new OwnedRwLockMappedWriteGuard
for a component of the locked
data.
This operation cannot fail as the OwnedRwLockWriteGuard
passed in
already locked the data.
This is an associated function that needs to be used as
OwnedRwLockWriteGuard::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, OwnedRwLockWriteGuard};
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
struct Foo(u32);
let lock = Arc::new(RwLock::new(Foo(1)));
{
let lock = Arc::clone(&lock);
let mut mapped = OwnedRwLockWriteGuard::map(lock.write_owned().await, |f| &mut f.0);
*mapped = 2;
}
assert_eq!(Foo(2), *lock.read().await);
pub fn downgrade_map<F, U>(
this: OwnedRwLockWriteGuard<T>,
f: F,
) -> OwnedRwLockReadGuard<T, U>
pub fn downgrade_map<F, U>( this: OwnedRwLockWriteGuard<T>, f: F, ) -> OwnedRwLockReadGuard<T, U>
Makes a new OwnedRwLockReadGuard
for a component of the locked data.
This operation cannot fail as the OwnedRwLockWriteGuard
passed in already
locked the data.
This is an associated function that needs to be used as
OwnedRwLockWriteGuard::downgrade_map(..)
. A method would interfere with methods of
the same name on the contents of the locked data.
Inside of f
, you retain exclusive access to the data, despite only being given a &T
. Handing out a
&mut T
would result in unsoundness, as you could use interior mutability.
§Examples
use std::sync::Arc;
use tokio::sync::{RwLock, OwnedRwLockWriteGuard};
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
struct Foo(u32);
let lock = Arc::new(RwLock::new(Foo(1)));
let guard = Arc::clone(&lock).write_owned().await;
let mapped = OwnedRwLockWriteGuard::downgrade_map(guard, |f| &f.0);
let foo = lock.read_owned().await;
assert_eq!(foo.0, *mapped);
pub fn try_map<F, U>(
this: OwnedRwLockWriteGuard<T>,
f: F,
) -> Result<OwnedRwLockMappedWriteGuard<T, U>, OwnedRwLockWriteGuard<T>> ⓘ
pub fn try_map<F, U>( this: OwnedRwLockWriteGuard<T>, f: F, ) -> Result<OwnedRwLockMappedWriteGuard<T, U>, OwnedRwLockWriteGuard<T>> ⓘ
Attempts to make a new OwnedRwLockMappedWriteGuard
for a component
of the locked data. The original guard is returned if the closure
returns None
.
This operation cannot fail as the OwnedRwLockWriteGuard
passed in
already locked the data.
This is an associated function that needs to be
used as OwnedRwLockWriteGuard::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, OwnedRwLockWriteGuard};
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
struct Foo(u32);
let lock = Arc::new(RwLock::new(Foo(1)));
{
let guard = Arc::clone(&lock).write_owned().await;
let mut guard = OwnedRwLockWriteGuard::try_map(guard, |f| Some(&mut f.0)).expect("should not fail");
*guard = 2;
}
assert_eq!(Foo(2), *lock.read().await);
pub fn try_downgrade_map<F, U>(
this: OwnedRwLockWriteGuard<T>,
f: F,
) -> Result<OwnedRwLockReadGuard<T, U>, OwnedRwLockWriteGuard<T>> ⓘ
pub fn try_downgrade_map<F, U>( this: OwnedRwLockWriteGuard<T>, f: F, ) -> Result<OwnedRwLockReadGuard<T, U>, OwnedRwLockWriteGuard<T>> ⓘ
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 OwnedRwLockWriteGuard
passed in already
locked the data.
This is an associated function that needs to be
used as OwnedRwLockWriteGuard::try_downgrade_map(...)
. A method would interfere with
methods of the same name on the contents of the locked data.
Inside of f
, you retain exclusive access to the data, despite only being given a &T
. Handing out a
&mut T
would result in unsoundness, as you could use interior mutability.
If this function returns Err(...)
, the lock is never unlocked nor downgraded.
§Examples
use std::sync::Arc;
use tokio::sync::{RwLock, OwnedRwLockWriteGuard};
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
struct Foo(u32);
let lock = Arc::new(RwLock::new(Foo(1)));
let guard = Arc::clone(&lock).write_owned().await;
let guard = OwnedRwLockWriteGuard::try_downgrade_map(guard, |f| Some(&f.0)).expect("should not fail");
let foo = lock.read_owned().await;
assert_eq!(foo.0, *guard);
pub fn into_mapped(
this: OwnedRwLockWriteGuard<T>,
) -> OwnedRwLockMappedWriteGuard<T>
pub fn into_mapped( this: OwnedRwLockWriteGuard<T>, ) -> OwnedRwLockMappedWriteGuard<T>
Converts this OwnedRwLockWriteGuard
into an
OwnedRwLockMappedWriteGuard
. This method can be used to store a
non-mapped guard in a struct field that expects a mapped guard.
This is equivalent to calling OwnedRwLockWriteGuard::map(guard, |me| me)
.
pub fn downgrade(self) -> OwnedRwLockReadGuard<T>
pub fn downgrade(self) -> OwnedRwLockReadGuard<T>
Atomically downgrades a write lock into a read lock without allowing any writers to take exclusive access of the lock in the meantime.
Note: This won’t necessarily allow any additional readers to acquire
locks, since RwLock
is fair and it is possible that a writer is next
in line.
Returns an RAII guard which will drop this read access of the RwLock
when dropped.
§Examples
let lock = Arc::new(RwLock::new(1));
let n = lock.clone().write_owned().await;
let cloned_lock = lock.clone();
let handle = tokio::spawn(async move {
*cloned_lock.write_owned().await = 2;
});
let n = n.downgrade();
assert_eq!(*n, 1, "downgrade is atomic");
drop(n);
handle.await.unwrap();
assert_eq!(*lock.read().await, 2, "second writer obtained write lock");
pub fn rwlock(this: &OwnedRwLockWriteGuard<T>) -> &Arc<RwLock<T>>
pub fn rwlock(this: &OwnedRwLockWriteGuard<T>) -> &Arc<RwLock<T>>
Returns a reference to the original Arc<RwLock>
.
§Examples
use std::sync::Arc;
use tokio::sync::{RwLock, OwnedRwLockWriteGuard};
let lock = Arc::new(RwLock::new(1));
let guard = lock.clone().write_owned().await;
assert!(Arc::ptr_eq(&lock, OwnedRwLockWriteGuard::rwlock(&guard)));
Trait Implementations§
§impl<T> Debug for OwnedRwLockWriteGuard<T>
impl<T> Debug for OwnedRwLockWriteGuard<T>
§impl<T> Deref for OwnedRwLockWriteGuard<T>where
T: ?Sized,
impl<T> Deref for OwnedRwLockWriteGuard<T>where
T: ?Sized,
§impl<T> DerefMut for OwnedRwLockWriteGuard<T>where
T: ?Sized,
impl<T> DerefMut for OwnedRwLockWriteGuard<T>where
T: ?Sized,
§impl<T> Display for OwnedRwLockWriteGuard<T>
impl<T> Display for OwnedRwLockWriteGuard<T>
§impl<T> Drop for OwnedRwLockWriteGuard<T>where
T: ?Sized,
impl<T> Drop for OwnedRwLockWriteGuard<T>where
T: ?Sized,
impl<T> Send for OwnedRwLockWriteGuard<T>
impl<T> Sync for OwnedRwLockWriteGuard<T>
Auto Trait Implementations§
impl<T> Freeze for OwnedRwLockWriteGuard<T>where
T: ?Sized,
impl<T> !RefUnwindSafe for OwnedRwLockWriteGuard<T>
impl<T> Unpin for OwnedRwLockWriteGuard<T>
impl<T> !UnwindSafe for OwnedRwLockWriteGuard<T>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> ByteSized for T
impl<T> ByteSized for T
Source§const BYTE_ALIGN: usize = _
const BYTE_ALIGN: usize = _
Source§fn byte_align(&self) -> usize
fn byte_align(&self) -> usize
Source§fn ptr_size_ratio(&self) -> [usize; 2]
fn ptr_size_ratio(&self) -> [usize; 2]
Source§impl<T, R> Chain<R> for Twhere
T: ?Sized,
impl<T, R> Chain<R> for Twhere
T: ?Sized,
Source§impl<T> ExtAny for T
impl<T> ExtAny for T
Source§fn type_hash_with<H: Hasher>(&self, hasher: H) -> u64
fn type_hash_with<H: Hasher>(&self, hasher: H) -> u64
TypeId
of Self
using a custom hasher.Source§fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
Source§impl<T> ExtMem for Twhere
T: ?Sized,
impl<T> ExtMem for Twhere
T: ?Sized,
Source§const NEEDS_DROP: bool = _
const NEEDS_DROP: bool = _
Source§fn mem_align_of<T>() -> usize
fn mem_align_of<T>() -> usize
Source§fn mem_align_of_val(&self) -> usize
fn mem_align_of_val(&self) -> usize
Source§fn mem_size_of<T>() -> usize
fn mem_size_of<T>() -> usize
Source§fn mem_size_of_val(&self) -> usize
fn mem_size_of_val(&self) -> usize
Source§fn mem_needs_drop(&self) -> bool
fn mem_needs_drop(&self) -> bool
true
if dropping values of this type matters. Read moreSource§fn mem_forget(self)where
Self: Sized,
fn mem_forget(self)where
Self: Sized,
self
without running its destructor. Read moreSource§fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
Source§unsafe fn mem_zeroed<T>() -> T
unsafe fn mem_zeroed<T>() -> T
unsafe_layout
only.T
represented by the all-zero byte-pattern. Read moreSource§unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
unsafe_layout
only.T
represented by the all-zero byte-pattern. Read moreSource§fn mem_as_bytes(&self) -> &[u8] ⓘ
fn mem_as_bytes(&self) -> &[u8] ⓘ
unsafe_slice
only.§impl<S> FromSample<S> for S
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
Source§impl<T> Hook for T
impl<T> Hook for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more§impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
fn into_sample(self) -> T
§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T, U> ToSample<U> for Twhere
U: FromSample<T>,
impl<T, U> ToSample<U> for Twhere
U: FromSample<T>,
fn to_sample_(self) -> U
Source§impl<R> TryRngCore for R
impl<R> TryRngCore for R
Source§type Error = Infallible
type Error = Infallible
Source§fn try_next_u32(&mut self) -> Result<u32, <R as TryRngCore>::Error> ⓘ
fn try_next_u32(&mut self) -> Result<u32, <R as TryRngCore>::Error> ⓘ
u32
.Source§fn try_next_u64(&mut self) -> Result<u64, <R as TryRngCore>::Error> ⓘ
fn try_next_u64(&mut self) -> Result<u64, <R as TryRngCore>::Error> ⓘ
u64
.Source§fn try_fill_bytes(
&mut self,
dst: &mut [u8],
) -> Result<(), <R as TryRngCore>::Error> ⓘ
fn try_fill_bytes( &mut self, dst: &mut [u8], ) -> Result<(), <R as TryRngCore>::Error> ⓘ
dest
entirely with random data.Source§fn unwrap_mut(&mut self) -> UnwrapMut<'_, Self>
fn unwrap_mut(&mut self) -> UnwrapMut<'_, Self>
UnwrapMut
wrapper.