std::atomic_flag_clear, std::atomic_flag_clear_explicit
来自 cppreference.cn
定义于头文件 <atomic> |
||
void atomic_flag_clear( volatile std::atomic_flag* obj ) noexcept; |
(1) | (C++11 起) |
void atomic_flag_clear( std::atomic_flag* obj ) noexcept; |
(2) | (C++11 起) |
void atomic_flag_clear_explicit( volatile std::atomic_flag* obj, std::memory_order order ) noexcept; |
(3) | (C++11 起) |
void atomic_flag_clear_explicit( std::atomic_flag* obj, std::memory_order order ) noexcept; |
(4) | (C++11 起) |
原子地将 obj 所指向的 std::atomic_flag 的状态更改为清除(false)。
1,2) 内存同步顺序为 std::memory_order_seq_cst。
3,4) 内存同步顺序为 order。
如果 order 是 std::memory_order_consume、std::memory_order_acquire 和 std::memory_order_acq_rel 之一,则行为未定义。
目录 |
[编辑] 参数
obj | - | 指向要访问的 std::atomic_flag 的指针 |
顺序 | - | 内存同步顺序 |
[编辑] 注意
std::atomic_flag_clear
和 std::atomic_flag_clear_explicit
可以分别实现为 obj->clear() 和 obj->clear(order)。
[编辑] 缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 发布时的行为 | 正确的行为 |
---|---|---|---|
LWG 2138 | C++11 | order 可以是 std::memory_order_consume | 在这种情况下行为未定义 |
[编辑] 参阅
(C++11) |
无锁布尔原子类型 (类) |
原子地将标志设置为 true 并返回其先前的值 (函数) | |
(C++11) |
定义给定原子操作的内存排序约束 (枚举) |
C 文档 用于 atomic_flag_clear, atomic_flag_clear_explicit
|