pub struct SyncUnsafeCell<T: ?Sized> { /* private fields */ }
Expand description
UnsafeCell
, but Sync
.
This is just an UnsafeCell
, except it implements Sync
if T
implements Sync
.
UnsafeCell
doesn’t implement Sync
, to prevent accidental mis-use. You can use
SyncUnsafeCell
instead of UnsafeCell
to allow it to be shared between threads, if that’s
intentional. Providing proper synchronization is still the task of the user, making this type
just as unsafe to use.
See UnsafeCell
for details.
Implementations§
Source§impl<T> SyncUnsafeCell<T>
impl<T> SyncUnsafeCell<T>
Sourcepub const fn new(value: T) -> Self
pub const fn new(value: T) -> Self
Constructs a new instance of SyncUnsafeCell
which will wrap the specified value.
Sourcepub fn into_inner(self) -> T
pub fn into_inner(self) -> T
Unwraps the value.
Source§impl<T: ?Sized> SyncUnsafeCell<T>
impl<T: ?Sized> SyncUnsafeCell<T>
Sourcepub const fn get(&self) -> *mut T
pub const fn get(&self) -> *mut T
Gets a mutable pointer to the wrapped value.
This can be cast to a pointer of any kind. Ensure that the access is unique (no active
references, mutable or not) when casting to &mut T
, and ensure that there are no
mutations or mutable aliases going on when casting to &T
Sourcepub fn get_mut(&mut self) -> &mut T
pub fn get_mut(&mut self) -> &mut T
Returns a mutable reference to the underlying data.
This call borrows the SyncUnsafeCell
mutably (at compile-time) which guarantees that we
possess the only reference.
Sourcepub const fn raw_get(this: *const Self) -> *mut T
pub const fn raw_get(this: *const Self) -> *mut T
Gets a mutable pointer to the wrapped value.
See UnsafeCell::get
for details.
Trait Implementations§
Source§impl<T: Default> Default for SyncUnsafeCell<T>
impl<T: Default> Default for SyncUnsafeCell<T>
Source§fn default() -> SyncUnsafeCell<T>
fn default() -> SyncUnsafeCell<T>
Creates an SyncUnsafeCell
, with the Default
value for T.
Source§impl<T> From<T> for SyncUnsafeCell<T>
impl<T> From<T> for SyncUnsafeCell<T>
Source§fn from(t: T) -> SyncUnsafeCell<T>
fn from(t: T) -> SyncUnsafeCell<T>
Creates a new SyncUnsafeCell<T>
containing the given value.