Trait crossbeam_utils::consume::AtomicConsume [−][src]
pub trait AtomicConsume { type Val; fn load_consume(&self) -> Self::Val; }
Trait which allows reading from an atomic type with "consume" ordering.
Associated Types
type Val
Type returned by load_consume
.
Required Methods
fn load_consume(&self) -> Self::Val
Loads a value from the atomic using a "consume" memory ordering.
This is similar to the "acquire" ordering, except that an ordering is only guaranteed with operations that "depend on" the result of the load. However consume loads are usually much faster than acquire loads on architectures with a weak memory model since they don't require memory fence instructions.
The exact definition of "depend on" is a bit vague, but it works as you would expect in practice since a lot of software, especially the Linux kernel, rely on this behavior.
This is currently only implemented on ARM and AArch64, where a fence
can be avoided. On other architectures this will fall back to a simple
load(Ordering::Acquire)
.
Implementations on Foreign Types
impl AtomicConsume for AtomicBool
[src]
impl AtomicConsume for AtomicBool
type Val = bool
fn load_consume(&self) -> Self::Val
[src]
fn load_consume(&self) -> Self::Val
impl AtomicConsume for AtomicUsize
[src]
impl AtomicConsume for AtomicUsize
type Val = usize
fn load_consume(&self) -> Self::Val
[src]
fn load_consume(&self) -> Self::Val
impl AtomicConsume for AtomicIsize
[src]
impl AtomicConsume for AtomicIsize
type Val = isize
fn load_consume(&self) -> Self::Val
[src]
fn load_consume(&self) -> Self::Val
impl<T> AtomicConsume for AtomicPtr<T>
[src]
impl<T> AtomicConsume for AtomicPtr<T>
type Val = *mut T
fn load_consume(&self) -> Self::Val
[src]
fn load_consume(&self) -> Self::Val