std::atomic_flag_test_and_set, std::atomic_flag_test_and_set_explicit
来自 cppreference.com
定义在头文件 <atomic> 中 |
||
bool atomic_flag_test_and_set( volatile std::atomic_flag* obj ) noexcept; |
(1) | (自 C++11 起) |
bool atomic_flag_test_and_set( std::atomic_flag* obj ) noexcept; |
(2) | (自 C++11 起) |
bool atomic_flag_test_and_set_explicit( volatile std::atomic_flag* obj, std::memory_order order ) noexcept; |
(3) | (自 C++11 起) |
bool atomic_flag_test_and_set_explicit( std::atomic_flag* obj, std::memory_order order ) noexcept; |
(4) | (自 C++11 起) |
原子地将 std::atomic_flag 指向 obj 的状态更改为设置 (true) 并返回它之前持有的值。
1,2) 内存同步顺序为 std::memory_order_seq_cst.
3,4) 内存同步顺序为 order.
内容 |
[编辑] 参数
obj | - | 指向要访问的 std::atomic_flag 的指针 |
order | - | 内存同步顺序 |
[编辑] 返回值
由 obj 指向的标志先前持有的值。
[编辑] 注意事项
std::atomic_flag_test_and_set
和 std::atomic_flag_test_and_set_explicit
可以分别实现为 obj->test_and_set() 和 obj->test_and_set(order)。
[编辑] 示例
自旋锁互斥锁可以使用 std::atomic_flag
在用户空间中实现。
运行此代码
#include <atomic> #include <iostream> #include <thread> #include <vector> std::atomic_flag lock = ATOMIC_FLAG_INIT; void f(int n) { for (int cnt = 0; cnt < 100; ++cnt) { while (std::atomic_flag_test_and_set_explicit(&lock, std::memory_order_acquire)) ; // spin until the lock is acquired std::cout << "Output from thread " << n << '\n'; std::atomic_flag_clear_explicit(&lock, std::memory_order_release); } } int main() { std::vector<std::thread> v; for (int n = 0; n < 10; ++n) v.emplace_back(f, n); for (auto& t : v) t.join(); }
输出
Output from thread 2 Output from thread 6 Output from thread 7 ...<exactly 1000 lines>...
[编辑] 另请参阅
(C++11) |
无锁布尔原子类型 (类) |
(C++11)(C++11) |
原子地将标志的值设置为 false (函数) |
(C++11) |
定义给定原子操作的内存排序约束 (枚举) |
C 文档 for atomic_flag_test_and_set, atomic_flag_test_and_set_explicit
|