1.0.0[−][src]Struct std::cell::Cell  
A mutable memory location.
Examples
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);Run
See the module-level documentation for more.
Methods
impl<T> Cell<T>[src]
pub const fn new(value: T) -> Cell<T>[src]
Creates a new Cell containing the given value.
Examples
use std::cell::Cell; let c = Cell::new(5);Run
pub fn set(&self, val: T)[src]
pub fn swap(&self, other: &Cell<T>)1.17.0[src]
Swaps the values of two Cells.
Difference with std::mem::swap is that this function doesn't require &mut reference.
Examples
use std::cell::Cell; let c1 = Cell::new(5i32); let c2 = Cell::new(10i32); c1.swap(&c2); assert_eq!(10, c1.get()); assert_eq!(5, c2.get());Run
pub fn replace(&self, val: T) -> T1.17.0[src]
Replaces the contained value, and returns it.
Examples
use std::cell::Cell; let cell = Cell::new(5); assert_eq!(cell.get(), 5); assert_eq!(cell.replace(10), 5); assert_eq!(cell.get(), 10);Run
pub fn into_inner(self) -> T1.17.0[src]
impl<T> Cell<T> where
    T: Copy, [src]
T: Copy,
pub fn get(&self) -> T[src]
Returns a copy of the contained value.
Examples
use std::cell::Cell; let c = Cell::new(5); let five = c.get();Run
pub fn update<F>(&self, f: F) -> T where
    F: FnOnce(T) -> T, [src]
F: FnOnce(T) -> T,
impl<T> Cell<T> where
    T: ?Sized, [src]
T: ?Sized,
pub const fn as_ptr(&self) -> *mut T1.12.0[src]
Returns a raw pointer to the underlying data in this cell.
Examples
use std::cell::Cell; let c = Cell::new(5); let ptr = c.as_ptr();Run
pub fn get_mut(&mut self) -> &mut T1.11.0[src]
Returns a mutable reference to the underlying data.
This call borrows Cell mutably (at compile-time) which guarantees
that we possess the only reference.
Examples
use std::cell::Cell; let mut c = Cell::new(5); *c.get_mut() += 1; assert_eq!(c.get(), 6);Run
pub fn from_mut(t: &mut T) -> &Cell<T>1.37.0[src]
impl<T> Cell<T> where
    T: Default, [src]
T: Default,
impl<T> Cell<[T]>[src]
pub fn as_slice_of_cells(&self) -> &[Cell<T>]1.37.0[src]
Trait Implementations
impl<T> Clone for Cell<T> where
    T: Copy, [src]
T: Copy,
impl<T, U> CoerceUnsized<Cell<U>> for Cell<T> where
    T: CoerceUnsized<U>, [src]
T: CoerceUnsized<U>,
impl<T> Debug for Cell<T> where
    T: Copy + Debug, [src]
T: Copy + Debug,
impl<T> Default for Cell<T> where
    T: Default, [src]
T: Default,
impl<T> Eq for Cell<T> where
    T: Eq + Copy, 1.2.0[src]
T: Eq + Copy,
impl<T> From<T> for Cell<T>1.12.0[src]
impl<T> Ord for Cell<T> where
    T: Ord + Copy, 1.10.0[src]
T: Ord + Copy,
fn cmp(&self, other: &Cell<T>) -> Ordering[src]
#[must_use]fn max(self, other: Self) -> Self1.21.0[src]
#[must_use]fn min(self, other: Self) -> Self1.21.0[src]
#[must_use]fn clamp(self, min: Self, max: Self) -> Self[src]
impl<T> PartialEq<Cell<T>> for Cell<T> where
    T: PartialEq<T> + Copy, [src]
T: PartialEq<T> + Copy,
impl<T> PartialOrd<Cell<T>> for Cell<T> where
    T: PartialOrd<T> + Copy, 1.10.0[src]
T: PartialOrd<T> + Copy,
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> Send for Cell<T> where
    T: Send + ?Sized, [src]
T: Send + ?Sized,
impl<T> !Sync for Cell<T> where
    T: ?Sized, [src]
T: ?Sized,
Auto Trait Implementations
impl<T> !RefUnwindSafe for Cell<T>
impl<T: ?Sized> Unpin for Cell<T> where
    T: Unpin, 
T: Unpin,
impl<T: ?Sized> UnwindSafe for Cell<T> where
    T: UnwindSafe, 
T: UnwindSafe,
Blanket Implementations
impl<T> Any for T where
    T: 'static + ?Sized, [src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
    T: ?Sized, [src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
    T: ?Sized, [src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T[src]
impl<T> From<!> for T[src]
impl<T> From<T> for T[src]
impl<T, U> Into<U> for T where
    U: From<T>, [src]
U: From<T>,
impl<T> ToOwned for T where
    T: Clone, [src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
fn to_owned(&self) -> T[src]
fn clone_into(&self, target: &mut T)[src]
impl<T, U> TryFrom<U> for T where
    U: Into<T>, [src]
U: Into<T>,
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> TryInto<U> for T where
    U: TryFrom<T>, [src]
U: TryFrom<T>,