Defined in header <stdatomic.h> | ||
---|---|---|
#define ATOMIC_VAR_INIT(value) /* unspecified */ | (since C11) (deprecated in C17) (removed in C23) |
Expands to an expression that can be used to initialize an atomic variable of the same type as value
.
The initial value of atomic object of automatic storage duration that is not explicitly initialized is indeterminate. The default (zero) initialization of static and thread-local variables produces a valid value however.
When initializing an atomic variable, any concurrent access, even through an atomic operation, is a data race (it may happen if the address is immediately passed to another thread with a memory_order_relaxed
operation).
This macro was a part of early draft design for C11 atomic types. It is not needed in C11, and is deprecated in C17 and removed in C23.
The following behavior-changing defect reports were applied retroactively to previously published C standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
DR 485 | C11 | the specification was redundant and contradictory to the core language | fixed |
(C11) | initializes a new atomic_flag (macro constant) |
C++ documentation for ATOMIC_VAR_INIT |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/c/atomic/ATOMIC_VAR_INIT