#[repr(transparent)] pub struct Cell<T> where T: ?Sized, { /* fields omitted */ }
A mutable memory location.
In this example, you can see that Cell<T>
enables mutation inside an immutable struct. In other words, it enables "interior mutability".
use std::cell::Cell; struct SomeStruct { regular_field: u8, special_field: Cell<u8>, } let my_struct = SomeStruct { regular_field: 0, special_field: Cell::new(1), }; let new_value = 100; // ERROR: `my_struct` is immutable // my_struct.regular_field = new_value; // WORKS: although `my_struct` is immutable, `special_field` is a `Cell`, // which can always be mutated my_struct.special_field.set(new_value); assert_eq!(my_struct.special_field.get(), new_value);
See the module-level documentation for more.
impl<T> Cell<T> where
T: Copy,
[src]
pub fn get(&self) -> T
[src]
Returns a copy of the contained value.
pub fn update<F>(&self, f: F) -> T where
F: FnOnce(T) -> T,
[src]
Updates the contained value using a function and returns the new value.
impl<T> Cell<T>
[src]
pub const fn new(value: T) -> Cell<T>
[src]
pub fn set(&self, val: T)
[src]
pub fn swap(&self, other: &Cell<T>)
[src]1.17.0
Swaps the values of two Cells. Difference with std::mem::swap
is that this function doesn't require &mut
reference.
pub fn replace(&self, val: T) -> T
[src]1.17.0
Replaces the contained value, and returns it.
pub fn into_inner(self) -> T
[src]1.17.0
Unwraps the value.
impl<T> Cell<T> where
T: ?Sized,
[src]
pub const fn as_ptr(&self) -> *mut T
[src]1.12.0
Returns a raw pointer to the underlying data in this cell.
pub fn get_mut(&mut self) -> &mut T
[src]1.11.0
impl<'_, F> Future for &'_ mut F where F: Unpin + Future + ?Sized, type Output = <F as Future>::Output; impl<'_, I> Iterator for &'_ mut I where I: Iterator + ?Sized, type Item = <I as Iterator>::Item; impl<'_, R: Read + ?Sized> Read for &'_ mut R impl<'_, W: Write + ?Sized> Write for &'_ mut W
Returns a mutable reference to the underlying data.
This call borrows Cell
mutably (at compile-time) which guarantees that we possess the only reference.
pub fn from_mut(t: &mut T) -> &Cell<T>
[src]1.37.0
Returns a &Cell<T>
from a &mut T
impl<T> Cell<T> where
T: Default,
[src]
pub fn take(&self) -> T
[src]1.17.0
Takes the value of the cell, leaving Default::default()
in its place.
impl<T> Cell<[T]>
[src]
pub fn as_slice_of_cells(&self) -> &[Cell<T>]
[src]1.37.0
Returns a &[Cell<T>]
from a &Cell<[T]>
impl<T> !Sync for Cell<T> where
T: ?Sized,
[src]
impl<T> Default for Cell<T> where
T: Default,
[src]
impl<T> Clone for Cell<T> where
T: Copy,
[src]
fn clone(&self) -> Cell<T>
[src]
fn clone_from(&mut self, source: &Self)
[src]
Performs copy-assignment from source
. Read more
impl<T> Eq for Cell<T> where
T: Copy + Eq,
[src]1.2.0
impl<T> PartialOrd<Cell<T>> for Cell<T> where
T: Copy + PartialOrd<T>,
[src]1.10.0
fn partial_cmp(&self, other: &Cell<T>) -> Option<Ordering>
[src]
fn lt(&self, other: &Cell<T>) -> bool
[src]
fn le(&self, other: &Cell<T>) -> bool
[src]
fn gt(&self, other: &Cell<T>) -> bool
[src]
fn ge(&self, other: &Cell<T>) -> bool
[src]
impl<T> Ord for Cell<T> where
T: Copy + Ord,
[src]1.10.0
fn cmp(&self, other: &Cell<T>) -> Ordering
[src]
fn max(self, other: Self) -> Self
[src]1.21.0
Compares and returns the maximum of two values. Read more
fn min(self, other: Self) -> Self
[src]1.21.0
Compares and returns the minimum of two values. Read more
fn clamp(self, min: Self, max: Self) -> Self
[src]
Restrict a value to a certain interval. Read more
impl<T> Debug for Cell<T> where
T: Copy + Debug,
[src]
impl<T> PartialEq<Cell<T>> for Cell<T> where
T: Copy + PartialEq<T>,
[src]
fn eq(&self, other: &Cell<T>) -> bool
[src]
fn ne(&self, other: &Rhs) -> bool
[src]
This method tests for !=
.
impl<T> Send for Cell<T> where
T: Send + ?Sized,
[src]
impl<T, U> CoerceUnsized<Cell<U>> for Cell<T> where
T: CoerceUnsized<U>,
[src]
impl<T> From<T> for Cell<T>
[src]1.12.0
impl<T: ?Sized> UnwindSafe for Cell<T> where
T: UnwindSafe,
impl<T> !RefUnwindSafe for Cell<T>
impl<T: ?Sized> Unpin for Cell<T> where
T: Unpin,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
impl<T> From<T> for T
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
fn borrow(&self) -> &T
[src]
impl<'_, F> Future for &'_ mut F where F: Unpin + Future + ?Sized, type Output = <F as Future>::Output; impl<'_, I> Iterator for &'_ mut I where I: Iterator + ?Sized, type Item = <I as Iterator>::Item; impl<'_, R: Read + ?Sized> Read for &'_ mut R impl<'_, W: Write + ?Sized> Write for &'_ mut W
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
fn borrow_mut(&mut self) -> &mut T
[src]
impl<'_, F> Future for &'_ mut F where F: Unpin + Future + ?Sized, type Output = <F as Future>::Output; impl<'_, I> Iterator for &'_ mut I where I: Iterator + ?Sized, type Item = <I as Iterator>::Item; impl<'_, R: Read + ?Sized> Read for &'_ mut R impl<'_, W: Write + ?Sized> Write for &'_ mut W
impl<T> Any for T where
T: 'static + ?Sized,
[src]
impl<T> ToOwned for T where
T: Clone,
[src]
© 2010 The Rust Project Developers
Licensed under the Apache License, Version 2.0 or the MIT license, at your option.
https://doc.rust-lang.org/std/cell/struct.Cell.html