#[repr(transparent)]
pub struct Cell<T: ?Sized> { /* private fields */ }
Expand description
可变的内存位置。
Cell<T>
具有与 UnsafeCell<T>
](UnsafeCell#memory-layout) 相同的 [内存布局和注意事项。
特别是,这意味着 Cell<T>
与其内部类型 T
具有相同的内存表示。
在这个例子中,您可以看到 Cell<T>
在一个不可变的结构中实现了变异。
换句话说,它实现了内部可变性。
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;
my_struct.special_field.set(new_value);
assert_eq!(my_struct.special_field.get(), new_value);
Run
有关更多信息,请参见 模块级文档。
创建一个包含给定值的新 Cell
。
use std::cell::Cell;
let c = Cell::new(5);
Run
设置包含的值。
use std::cell::Cell;
let c = Cell::new(5);
c.set(10);
Run
交换两个 Cell
的值。
与 std::mem::swap
的区别在于,这个函数不需要 &mut
引用。
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
用 val
替换包含的值,并返回旧的包含的值。
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
解开值,消耗 cell。
use std::cell::Cell;
let c = Cell::new(5);
let five = c.into_inner();
assert_eq!(five, 5);
Run
返回所包含值的副本。
use std::cell::Cell;
let c = Cell::new(5);
let five = c.get();
Run
🔬This is a nightly-only experimental API. (cell_update
#50186)
使用函数更新包含的值并返回新值。
#![feature(cell_update)]
use std::cell::Cell;
let c = Cell::new(5);
let new = c.update(|x| x + 1);
assert_eq!(new, 6);
assert_eq!(c.get(), 6);
Run
1.12.0 (const: 1.32.0) · source
返回指向此 cell 中底层数据的裸指针。
use std::cell::Cell;
let c = Cell::new(5);
let ptr = c.as_ptr();
Run
返回对底层数据的可变引用。
这个调用可变地 (在编译时) 借用了 Cell
,这保证了我们拥有唯一的引用。
但是要小心:此方法要求 self
是可变的,而使用 Cell
时通常不是这种情况。
如果您需要通过引用实现内部可变性,可以考虑使用 RefCell
,它通过其 borrow_mut
方法提供运行时检查的可变借用。
use std::cell::Cell;
let mut c = Cell::new(5);
*c.get_mut() += 1;
assert_eq!(c.get(), 6);
Run
从 &mut T
返回 &Cell<T>
use std::cell::Cell;
let slice: &mut [i32] = &mut [1, 2, 3];
let cell_slice: &Cell<[i32]> = Cell::from_mut(slice);
let slice_cell: &[Cell<i32>] = cell_slice.as_slice_of_cells();
assert_eq!(slice_cell.len(), 3);
Run
获取 cell 的值,将 Default::default()
保留在其位置。
use std::cell::Cell;
let c = Cell::new(5);
let five = c.take();
assert_eq!(five, 5);
assert_eq!(c.into_inner(), 0);
Run
从 &Cell<[T]>
返回 &[Cell<T>]
use std::cell::Cell;
let slice: &mut [i32] = &mut [1, 2, 3];
let cell_slice: &Cell<[i32]> = Cell::from_mut(slice);
let slice_cell: &[Cell<i32>] = cell_slice.as_slice_of_cells();
assert_eq!(slice_cell.len(), 3);
Run
🔬This is a nightly-only experimental API. (as_array_of_cells
#88248)
从 &Cell<[T; N]>
返回 &[Cell<T>; N]
#![feature(as_array_of_cells)]
use std::cell::Cell;
let mut array: [i32; 3] = [1, 2, 3];
let cell_array: &Cell<[i32; 3]> = Cell::from_mut(&mut array);
let array_cell: &[Cell<i32>; 3] = cell_array.as_array_of_cells();
Run
创建一个 Cell<T>
,使用 T 的 Default
值。
此方法测试 self
和 other
值是否相等,并由 ==
使用。
此方法测试 !=
。
默认实现几乎总是足够的,并且不应在没有充分理由的情况下被覆盖。
此方法测试的内容少于 (对于
self
和
other
),并且由
<
操作员使用。
Read more
此方法测试小于或等于 (对于
self
和
other
),并且由
<=
运算符使用。
Read more
此方法测试大于 (对于
self
和
other
),并且由
>
操作员使用。
Read more
此方法测试是否大于或等于 (对于
self
和
other
),并且由
>=
运算符使用。
Read more
调用 U::from(self)
。
也就是说,这种转换是 From<T> for U
实现选择执行的任何操作。