pub struct Ref<'b, T: ?Sized + 'b> {
value: NonNull<T>,
borrow: BorrowRef<'b>,
}
Expand description
Wraps a borrowed reference to a value in a RefCell
box.
A wrapper type for an immutably borrowed value from a RefCell<T>
.
See the module-level documentation for more.
Fields§
§value: NonNull<T>
§borrow: BorrowRef<'b>
Implementations§
Source§impl<'b, T: ?Sized> Ref<'b, T>
impl<'b, T: ?Sized> Ref<'b, T>
1.15.0 · Sourcepub fn clone(orig: &Ref<'b, T>) -> Ref<'b, T>
pub fn clone(orig: &Ref<'b, T>) -> Ref<'b, T>
Copies a Ref
.
The RefCell
is already immutably borrowed, so this cannot fail.
This is an associated function that needs to be used as
Ref::clone(...)
. A Clone
implementation or a method would interfere
with the widespread use of r.borrow().clone()
to clone the contents of
a RefCell
.
1.8.0 · Sourcepub fn map<U: ?Sized, F>(orig: Ref<'b, T>, f: F) -> Ref<'b, U>
pub fn map<U: ?Sized, F>(orig: Ref<'b, T>, f: F) -> Ref<'b, U>
Makes a new Ref
for a component of the borrowed data.
The RefCell
is already immutably borrowed, so this cannot fail.
This is an associated function that needs to be used as Ref::map(...)
.
A method would interfere with methods of the same name on the contents
of a RefCell
used through Deref
.
§Examples
1.63.0 · Sourcepub fn filter_map<U: ?Sized, F>(
orig: Ref<'b, T>,
f: F,
) -> Result<Ref<'b, U>, Self>
pub fn filter_map<U: ?Sized, F>( orig: Ref<'b, T>, f: F, ) -> Result<Ref<'b, U>, Self>
Makes a new Ref
for an optional component of the borrowed data. The
original guard is returned as an Err(..)
if the closure returns
None
.
The RefCell
is already immutably borrowed, so this cannot fail.
This is an associated function that needs to be used as
Ref::filter_map(...)
. A method would interfere with methods of the same
name on the contents of a RefCell
used through Deref
.
§Examples
1.35.0 · Sourcepub fn map_split<U: ?Sized, V: ?Sized, F>(
orig: Ref<'b, T>,
f: F,
) -> (Ref<'b, U>, Ref<'b, V>)
pub fn map_split<U: ?Sized, V: ?Sized, F>( orig: Ref<'b, T>, f: F, ) -> (Ref<'b, U>, Ref<'b, V>)
Splits a Ref
into multiple Ref
s for different components of the
borrowed data.
The RefCell
is already immutably borrowed, so this cannot fail.
This is an associated function that needs to be used as
Ref::map_split(...)
. A method would interfere with methods of the same
name on the contents of a RefCell
used through Deref
.
§Examples
Sourcepub fn leak(orig: Ref<'b, T>) -> &'b T
🔬This is a nightly-only experimental API. (cell_leak
#69099)
pub fn leak(orig: Ref<'b, T>) -> &'b T
cell_leak
#69099)Converts into a reference to the underlying data.
The underlying RefCell
can never be mutably borrowed from again and will always appear
already immutably borrowed. It is not a good idea to leak more than a constant number of
references. The RefCell
can be immutably borrowed again if only a smaller number of leaks
have occurred in total.
This is an associated function that needs to be used as
Ref::leak(...)
. A method would interfere with methods of the
same name on the contents of a RefCell
used through Deref
.
§Examples
Trait Implementations§
impl<'b, T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<Ref<'b, U>> for Ref<'b, T>
impl<T: ?Sized> DerefPure for Ref<'_, T>
impl<'b, T: ?Sized> PinCoerceUnsized for Ref<'b, T>
Auto Trait Implementations§
impl<'b, T> Freeze for Ref<'b, T>where
T: ?Sized,
impl<'b, T> !RefUnwindSafe for Ref<'b, T>
impl<'b, T> !Send for Ref<'b, T>
impl<'b, T> !Sync for Ref<'b, T>
impl<'b, T> Unpin for Ref<'b, T>where
T: ?Sized,
impl<'b, T> UnsafeUnpin for Ref<'b, T>where
T: ?Sized,
impl<'b, T> !UnwindSafe for Ref<'b, 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> SizedTypeProperties for T
impl<T> SizedTypeProperties for T
Source§#[doc(hidden)] const IS_ZST: bool = _
#[doc(hidden)] const IS_ZST: bool = _
sized_type_properties
)Source§#[doc(hidden)] const LAYOUT: Layout = _
#[doc(hidden)] const LAYOUT: Layout = _
sized_type_properties
)Source§#[doc(hidden)] const MAX_SLICE_LEN: usize = _
#[doc(hidden)] const MAX_SLICE_LEN: usize = _
sized_type_properties
)[Self]
. Read more