Struct bevy::utils::syncunsafecell::SyncUnsafeCell
source · pub struct SyncUnsafeCell<T>where
T: ?Sized,{ /* private fields */ }
Expand description
UnsafeCell
, but Sync
.
See tracking issue for upcoming native impl,
which should replace this one entirely (except from_mut
).
This is just an UnsafeCell
, except it implements Sync
if T
implements Sync
.
UnsafeCell
doesn’t implement Sync
, to prevent accidental misuse.
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) -> SyncUnsafeCell<T>
pub const fn new(value: T) -> SyncUnsafeCell<T>
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> SyncUnsafeCell<T>where
T: ?Sized,
impl<T> SyncUnsafeCell<T>where
T: ?Sized,
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 SyncUnsafeCell<T>) -> *mut T
pub const fn raw_get(this: *const SyncUnsafeCell<T>) -> *mut T
Gets a mutable pointer to the wrapped value.
See UnsafeCell::get
for details.
sourcepub fn from_mut(t: &mut T) -> &mut SyncUnsafeCell<T>
pub fn from_mut(t: &mut T) -> &mut SyncUnsafeCell<T>
Returns a &mut SyncUnsafeCell<T>
from a &mut T
.
source§impl<T> SyncUnsafeCell<[T]>
impl<T> SyncUnsafeCell<[T]>
sourcepub fn as_slice_of_cells(&self) -> &[SyncUnsafeCell<T>]
pub fn as_slice_of_cells(&self) -> &[SyncUnsafeCell<T>]
Returns a &[SyncUnsafeCell<T>]
from a &SyncUnsafeCell<[T]>
.
Examples
let slice: &mut [i32] = &mut [1, 2, 3];
let cell_slice: &SyncUnsafeCell<[i32]> = SyncUnsafeCell::from_mut(slice);
let slice_cell: &[SyncUnsafeCell<i32>] = cell_slice.as_slice_of_cells();
assert_eq!(slice_cell.len(), 3);
Trait Implementations§
source§impl<T> Default for SyncUnsafeCell<T>where
T: Default,
impl<T> Default for SyncUnsafeCell<T>where
T: Default,
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.
impl<T> Sync for SyncUnsafeCell<T>
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§
source§impl<T, U> AsBindGroupShaderType<U> for T
impl<T, U> AsBindGroupShaderType<U> for T
source§fn as_bind_group_shader_type(&self, _images: &RenderAssets<Image>) -> U
fn as_bind_group_shader_type(&self, _images: &RenderAssets<Image>) -> U
T
ShaderType
for self
. When used in AsBindGroup
derives, it is safe to assume that all images in self
exist.source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
source§impl<S> FromSample<S> for S
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
source§impl<T> FromWorld for Twhere
T: Default,
impl<T> FromWorld for Twhere
T: Default,
source§fn from_world(_world: &mut World) -> T
fn from_world(_world: &mut World) -> T
Self
using data from the given World
.