Enum Semantics Copy item path Source #[non_exhaustive]
pub enum Semantics {
Relaxed,
Coupled,
Ordered,
}
Expand description Memory ordering semantics for atomic operations
Each variant represents a group of compatible orderings . They determine how value
updates are synchronized between threads
This enum is marked as non-exhaustive Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
Relaxed
semantics
No synchronization constraints and the best performance
Set this when using a value in only one thread
Release
- Acquire
coupling semantics
Mild synchronization constraints and fair performance
A read will always see the preceding write (if one exists). Any operations that take place
before the write will also be seen, regardless of their semantics
Set this when using a value in multiple threads, unless certain that you need different
semantics
SeqCst
semantics
Maximum synchronization constraints and the worst performance
All memory operations will appear to be executed in a single, total order
Returns the memory ordering for read-write operations with these semantics
§ Returns
§ Usage
use ptr_cell::Semantics::Coupled;
use std::sync::atomic::Ordering;
assert_eq! (Coupled.read_write(), Ordering::AcqRel)
Returns the memory ordering for write operations with these semantics
§ Returns
§ Usage
use ptr_cell::Semantics::Coupled;
use std::sync::atomic::Ordering;
assert_eq! (Coupled.write(), Ordering::Release)
Returns the memory ordering for read operations with these semantics
§ Returns
§ Usage
use ptr_cell::Semantics::Coupled;
use std::sync::atomic::Ordering;
assert_eq! (Coupled.read(), Ordering::Acquire)
Performs copy-assignment from
source
.
Read more Formats the value using the given formatter.
Read more Returns the “default value” for a type.
Read more Compares and returns the maximum of two values.
Read more Compares and returns the minimum of two values.
Read more Restrict a value to a certain interval.
Read more Tests for self
and other
values to be equal, and is used by ==
.
Tests for !=
. The default implementation is almost always sufficient,
and should not be overridden without very good reason.
This method returns an ordering between
self
and
other
values if one exists.
Read more Tests less than (for
self
and
other
) and is used by the
<
operator.
Read more Tests less than or equal to (for
self
and
other
) and is used by the
<=
operator.
Read more Tests greater than (for
self
and
other
) and is used by the
>
operator.
Read more Tests greater than or equal to (for
self
and
other
) and is used by
the
>=
operator.
Read more Immutably borrows from an owned value.
Read more Mutably borrows from an owned value.
Read more 🔬 This is a nightly-only experimental API. (clone_to_uninit
)
Performs copy-assignment from
self
to
dest
.
Read more Returns the argument unchanged.
Calls U::from(self)
.
That is, this conversion is whatever the implementation of
From <T> for U
chooses to do.
The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning.
Read more Uses borrowed data to replace owned data, usually by cloning.
Read more The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.