Struct Ref
struct Ref<'b, T: ?Sized + 'b> { ... }
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.
Implementations
impl<'b, T: ?Sized> Ref<'b, T>
const fn clone(orig: &Ref<'b, T>) -> Ref<'b, T>Copies a
Ref.The
RefCellis already immutably borrowed, so this cannot fail.This is an associated function that needs to be used as
Ref::clone(...). ACloneimplementation or a method would interfere with the widespread use ofr.borrow().clone()to clone the contents of aRefCell.fn map<U: ?Sized, F>(orig: Ref<'b, T>, f: F) -> Ref<'b, U> where F: FnOnce(&T) -> &UMakes a new
Reffor a component of the borrowed data.The
RefCellis 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 aRefCellused throughDeref.Examples
use ; let c = new; let b1: = c.borrow; let b2: = map; assert_eq!fn filter_map<U: ?Sized, F>(orig: Ref<'b, T>, f: F) -> Result<Ref<'b, U>, Self> where F: FnOnce(&T) -> Option<&U>Makes a new
Reffor an optional component of the borrowed data. The original guard is returned as anErr(..)if the closure returnsNone.The
RefCellis 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 aRefCellused throughDeref.Examples
use ; let c = new; let b1: = c.borrow; let b2: = filter_map; assert_eq!;fn try_map<U: ?Sized, E, impl FnOnce(&T) -> Result<&U, E>: FnOnce(&T) -> Result<&U, E>>(orig: Ref<'b, T>, f: impl FnOnce(&T) -> Result<&U, E>) -> Result<Ref<'b, U>, (Self, E)>Tries to makes a new
Reffor a component of the borrowed data. On failure, the original guard is returned alongside with the error returned by the closure.The
RefCellis already immutably borrowed, so this cannot fail.This is an associated function that needs to be used as
Ref::try_map(...). A method would interfere with methods of the same name on the contents of aRefCellused throughDeref.Examples
use ; use ; let c = new; let b1: = c.borrow; let b2: = try_map; assert_eq!; let c = new; let b1: = c.borrow; let b2: = try_map; let = b2.unwrap_err; assert_eq!; assert_eq!;fn map_split<U: ?Sized, V: ?Sized, F>(orig: Ref<'b, T>, f: F) -> (Ref<'b, U>, Ref<'b, V>) where F: FnOnce(&T) -> (&U, &V)Splits a
Refinto multipleRefs for different components of the borrowed data.The
RefCellis 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 aRefCellused throughDeref.Examples
use ; let cell = new; let borrow = cell.borrow; let = map_split; assert_eq!; assert_eq!;const fn leak(orig: Ref<'b, T>) -> &'b TConverts into a reference to the underlying data.
The underlying
RefCellcan 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. TheRefCellcan 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 aRefCellused throughDeref.Examples
use ; let cell = new; let value = leak; assert_eq!; assert!; assert!;
impl<'b, T> Freeze for Ref<'b, T>
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>
impl<'b, T> UnwindSafe for Ref<'b, T>
impl<'b, T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized for Ref<'b, T>
impl<'b, T: ?Sized> PinCoerceUnsized for Ref<'b, T>
impl<P, T> Receiver for Ref<'b, T>
impl<T> Any for Ref<'b, T>
fn type_id(self: &Self) -> TypeId
impl<T> Borrow for Ref<'b, T>
fn borrow(self: &Self) -> &T
impl<T> BorrowMut for Ref<'b, T>
fn borrow_mut(self: &mut Self) -> &mut T
impl<T> From for Ref<'b, T>
fn from(t: T) -> TReturns the argument unchanged.
impl<T, U> Into for Ref<'b, T>
fn into(self: Self) -> UCalls
U::from(self).That is, this conversion is whatever the implementation of
[From]<T> for Uchooses to do.
impl<T, U> TryFrom for Ref<'b, T>
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
impl<T, U> TryInto for Ref<'b, T>
fn try_into(self: Self) -> Result<U, <U as TryFrom<T>>::Error>
impl<T: ?Sized + Debug> Debug for crate::cell::Ref<'_, T>
fn fmt(self: &Self, f: &mut Formatter<'_>) -> Result
impl<T: ?Sized + fmt::Display> Display for Ref<'_, T>
fn fmt(self: &Self, f: &mut fmt::Formatter<'_>) -> fmt::Result
impl<T: ?Sized> Deref for Ref<'_, T>
fn deref(self: &Self) -> &T