Struct std::cell::SyncUnsafeCell
source · [−]#[repr(transparent)]pub struct SyncUnsafeCell<T> where
T: ?Sized, { /* private fields */ }
sync_unsafe_cell
#95439)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
sourceimpl<T> SyncUnsafeCell<T>
impl<T> SyncUnsafeCell<T>
sourcepub const fn new(value: T) -> SyncUnsafeCell<T>
🔬This is a nightly-only experimental API. (sync_unsafe_cell
#95439)
pub const fn new(value: T) -> SyncUnsafeCell<T>
sync_unsafe_cell
#95439)Constructs a new instance of SyncUnsafeCell
which will wrap the specified value.
sourcepub const fn into_inner(self) -> T
🔬This is a nightly-only experimental API. (sync_unsafe_cell
#95439)
pub const fn into_inner(self) -> T
sync_unsafe_cell
#95439)Unwraps the value.
sourceimpl<T> SyncUnsafeCell<T> where
T: ?Sized,
impl<T> SyncUnsafeCell<T> where
T: ?Sized,
sourcepub const fn get(&self) -> *mut T
🔬This is a nightly-only experimental API. (sync_unsafe_cell
#95439)
pub const fn get(&self) -> *mut T
sync_unsafe_cell
#95439)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 const fn get_mut(&mut self) -> &mut T
🔬This is a nightly-only experimental API. (sync_unsafe_cell
#95439)
pub const fn get_mut(&mut self) -> &mut T
sync_unsafe_cell
#95439)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 SyncUnsafeCell<T>) -> *mut T
🔬This is a nightly-only experimental API. (sync_unsafe_cell
#95439)
pub const fn raw_get(this: *const SyncUnsafeCell<T>) -> *mut T
sync_unsafe_cell
#95439)Gets a mutable pointer to the wrapped value.
See UnsafeCell::get
for details.
Trait Implementations
sourceimpl<T> Debug for SyncUnsafeCell<T> where
T: ?Sized,
impl<T> Debug for SyncUnsafeCell<T> where
T: ?Sized,
sourceimpl<T> Default for SyncUnsafeCell<T> where
T: Default,
impl<T> Default for SyncUnsafeCell<T> where
T: Default,
sourcefn default() -> SyncUnsafeCell<T>
fn default() -> SyncUnsafeCell<T>
Creates an SyncUnsafeCell
, with the Default
value for T.
const: unstable · sourceimpl<T> From<T> for SyncUnsafeCell<T>
impl<T> From<T> for SyncUnsafeCell<T>
const: unstable · sourcefn from(t: T) -> SyncUnsafeCell<T>
fn from(t: T) -> SyncUnsafeCell<T>
Creates a new SyncUnsafeCell<T>
containing the given value.
impl<T, U> CoerceUnsized<SyncUnsafeCell<U>> for SyncUnsafeCell<T> where
T: CoerceUnsized<U>,
impl<T> Sync for SyncUnsafeCell<T> where
T: Sync + ?Sized,
Auto Trait Implementations
impl<T> !RefUnwindSafe for SyncUnsafeCell<T>
impl<T: ?Sized> Send for SyncUnsafeCell<T> where
T: Send,
impl<T: ?Sized> Unpin for SyncUnsafeCell<T> where
T: Unpin,
impl<T: ?Sized> UnwindSafe for SyncUnsafeCell<T> where
T: UnwindSafe,
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more