std::atomic<T>::is_lock_free

来自cppreference.com
< cpp‎ | atomic‎ | atomic
 
 
并发支持库
线程
(C++11)
(C++20)
(C++20)
this_thread 命名空间
(C++11)
(C++11)
(C++11)
原子类型
(C++11)
(C++20)
原子类型的初始化
(C++11)(C++20 中弃用)
(C++11)(C++20 中弃用)
原子操作的自由函数
原子标志的自由函数
内存序
互斥
(C++11)
通用锁管理
(C++11)
(C++11)
(C++11)
(C++11)(C++11)(C++11)
(C++11)
(C++11)
条件变量
(C++11)
信号量
闩与屏障
(C++20)
(C++20)
future
(C++11)
(C++11)
(C++11)
(C++11)
 
 
bool is_lock_free() const noexcept;
(1) (C++11 起)
bool is_lock_free() const volatile noexcept;
(2) (C++11 起)

检查此类型所有对象上的原子操作是否免锁。

参数

(无)

返回值

在此类型所有对象上的原子操作免锁的情况下返回 true,否则返回 false

注意

std::atomic_flag 以外的所有原子类型可用互斥或其他锁定操作实现,而不一定用免锁的原子 CPU 指令。也允许原子类型有时 免锁,例如给定架构上仅对齐的内存访问是天然原子的,此时同类型的错误对齐对象必须用锁。

C++ 标准推荐(但不要求)免锁操作都是免地址的,即适用于使用共享内存的进程间交流。

示例

#include <atomic>
#include <iostream>
#include <utility>
 
struct A { int a[100]; };
struct B { int x, y; };
 
int main()
{
    std::cout << std::boolalpha
              << "std::atomic<A> 是否免锁?"
              << std::atomic<A>{}.is_lock_free() << '\n'
              << "std::atomic<B> 是否免锁?"
              << std::atomic<B>{}.is_lock_free() << '\n';
}

可能的输出:

std::atomic<A> 是否免锁?false
std::atomic<B> 是否免锁?true

参阅

检查对该原子类型的操作是否是无锁的
(函数模板)
std::shared_ptr 特化原子操作
(函数模板)
[静态] (C++17)
指示该类型是否始终免锁
(公开静态成员常量)