命名空间
变体
操作

std::atomic_flag_clear, std::atomic_flag_clear_explicit

来自 cppreference.cn
< cpp‎ | atomic
 
 
并发支持库
线程
(C++11)
(C++20)
this_thread 命名空间
(C++11)
(C++11)
(C++11)
协同取消
互斥
(C++11)
通用锁管理
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
条件变量
(C++11)
信号量
闭锁器与栅栏
(C++20)
(C++20)
期物
(C++11)
(C++11)
(C++11)
(C++11)
安全回收
(C++26)
Hazard Pointers
原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(C++20 中已弃用)
(C++11)(C++20 中已弃用)
内存顺序
(C++11)(C++26 中已弃用)
原子操作的自由函数
原子标志的自由函数
atomic_flag_clearatomic_flag_clear_explicit
(C++11)(C++11)
 
定义于头文件 <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 起)

原子地更改 std::atomic_flag 的状态,该状态由 obj 指向以清除(false)。

1,2) 内存同步顺序为 std::memory_order_seq_cst
3,4) 内存同步顺序为 order
如果 orderstd::memory_order_consumestd::memory_order_acquirestd::memory_order_acq_rel 之一,则行为未定义。

目录

[edit] 参数

obj - 指向要访问的 std::atomic_flag 的指针
order - 内存同步顺序

[edit] 注解

std::atomic_flag_clearstd::atomic_flag_clear_explicit 可以分别实现为 obj->clear()obj->clear(order)

[edit] 缺陷报告

以下行为变更缺陷报告被追溯应用到先前发布的 C++ 标准。

DR 应用于 已发布行为 正确行为
LWG 2138 C++11 order 可以是 std::memory_order_consume 在这种情况下行为未定义

[edit] 参见

无锁布尔原子类型
(类) [编辑]
原子地将标志设置为 true 并返回其先前的值
(函数) [编辑]
为给定的原子操作定义内存顺序约束
(枚举) [编辑]
C 文档 关于 atomic_flag_clear, atomic_flag_clear_explicit