Namespaces
Variants

std::atomic_ref<T>:: is_lock_free

From cppreference.net
Concurrency support library
Threads
(C++11)
(C++20)
this_thread namespace
(C++11)
(C++11)
Cooperative cancellation
Mutual exclusion
Generic lock management
Condition variables
(C++11)
Semaphores
Latches and Barriers
(C++20)
(C++20)
Futures
(C++11)
(C++11)
(C++11)
Safe reclamation
Hazard pointers
Atomic types
(C++11)
(C++20)
Initialization of atomic types
(C++11) (deprecated in C++20)
(C++11) (deprecated in C++20)
Memory ordering
(C++11) (deprecated in C++26)
Free functions for atomic operations
Free functions for atomic flags
bool is_lock_free ( ) const noexcept ;
(C++20以降)

このオブジェクトに対するアトミック操作がロックフリーであるかどうかをチェックします。

目次

パラメータ

(なし)

戻り値

true このオブジェクトに対するアトミック操作がロックフリーである場合、 false それ以外の場合。

注記

std::atomic_flag を除くすべてのアトミック型は、ロックフリーなアトミックCPU命令を使用するのではなく、ミューテックスやその他のロック操作を使用して実装される可能性があります。アトミック型は 場合によっては ロックフリーであることも許可されており、例えば、特定のアーキテクチャで自然にアトミックなメモリアクセスが整列された場合のみである場合、同じ型の整列されていないオブジェクトはロックを使用する必要があります。

C++標準は、ロックフリーなアトミック操作がアドレスフリーでもあること、すなわち共有メモリを使用したプロセス間通信に適していることを推奨しています(必須ではありません)。

関連項目

型が常にロックフリーであることを示す
(公開静的メンバ定数)