The atomic module provides basic support for lock-free concurrent programming.
Performs the binary operation 'op' on val using 'mod' as the modifier.
T val
| The target variable. |
V1 mod
| The modifier to apply. |
Exchange exchangeWith
with the memory referenced by here
. This operation is both lock-free and atomic.
shared(T)* here
| The address of the destination variable. |
V exchangeWith
| The value to exchange. |
here
.Stores 'writeThis' to the memory referenced by 'here' if the value referenced by 'here' is equal to 'ifThis'. This operation is both lock-free and atomic.
shared(T)* here
| The address of the destination variable. |
V2 writeThis
| The value to store. |
V1 ifThis
| The comparison value. |
Stores 'writeThis' to the memory referenced by 'here' if the value referenced by 'here' is equal to the value referenced by 'ifThis'. The prior value referenced by 'here' is written to ifThis
and returned to the user. This operation is both lock-free and atomic.
shared(T)* here
| The address of the destination variable. |
V2 writeThis
| The value to store. |
V1* ifThis
| The address of the value to compare, and receives the prior value of here as output. |
Loads 'val' from memory and returns it. The memory barrier specified by 'ms' is applied to the operation, which is fully sequenced by default. Valid memory orders are MemoryOrder.raw, MemoryOrder.acq, and MemoryOrder.seq.
T val
| The target variable. |
Writes 'newval' into 'val'. The memory barrier specified by 'ms' is applied to the operation, which is fully sequenced by default. Valid memory orders are MemoryOrder.raw, MemoryOrder.rel, and MemoryOrder.seq.
T val
| The target variable. |
V1 newval
| The value to store. |
Specifies the memory ordering semantics of an atomic operation.
Not sequenced. Corresponds to LLVM AtomicOrdering.Monotonic and C++11/C11 memory_order_relaxed
.
Hoist-load + hoist-store barrier. Corresponds to LLVM AtomicOrdering.Acquire and C++11/C11 memory_order_acquire
.
Sink-load + sink-store barrier. Corresponds to LLVM AtomicOrdering.Release and C++11/C11 memory_order_release
.
Fully sequenced (acquire + release). Corresponds to LLVM AtomicOrdering.SequentiallyConsistent and C++11/C11 memory_order_seq_cst
.
Inserts a full load/store memory fence (on platforms that need it). This ensures that all loads and stores before a call to this function are executed before any loads and stores after the call.
© 1999–2019 The D Language Foundation
Licensed under the Boost License 1.0.
https://dlang.org/phobos/core_atomic.html