std::shared_timed_mutex
From cppreference.com
| ヘッダ <shared_mutex> で定義 |
||
| class shared_timed_mutex; |
(C++14以降) | |
shared_timed_mutex クラスは、複数のスレッドによって同時にアクセスされる共有データを保護するために使用できる同期プリミティブです。排他アクセスを容易にする他のミューテックス型とは対照的に、shared_timed_mutex には2つのレベルのアクセスがあります。
- 排他 - 1つのスレッドのみがミューテックスを所有できます。
- 共有 - 複数のスレッドが同じミューテックスの所有権を共有できます。
共有ミューテックスは通常、複数のリーダーがデータ競合を引き起こすことなく同時に同じリソースにアクセスできるが、ライターは1つだけである状況で使用されます。
timed_mutex と同様に、shared_timed_mutex は try_lock_for()、try_lock_until()、try_lock_shared_for()、try_lock_shared_until() メンバ関数を介して、タイムアウト付きで shared_timed_mutex の所有権を要求する機能を提供します。
shared_timed_mutex クラスは、SharedTimedMutex および StandardLayoutType のすべての要件を満たします。
目次 |
[編集] メンバ関数
| ミューテックスを構築します (public メンバ関数) | |
| ミューテックスを破棄します (public メンバ関数) | |
| operator= [削除] |
コピー代入不可 (public メンバ関数) |
排他ロック | |
| ミューテックスをロックします。ミューテックスが利用できない場合はブロックします (public メンバ関数) | |
| ミューテックスをロックしようとします。ミューテックスが利用できない場合は戻ります (public メンバ関数) | |
| ミューテックスをロックしようとします。ミューテックスが 指定されたタイムアウト期間利用できなかった場合は戻ります (public メンバ関数) | |
| ミューテックスをロックしようとします。ミューテックスが 指定された時刻まで利用できなかった場合は戻ります (public メンバ関数) | |
| ミューテックスをアンロックします (public メンバ関数) | |
| | |
| 共有所有権のためにミューテックスをロックします。ミューテックスが利用できない場合はブロックします (public メンバ関数) | |
| 共有所有権のためにミューテックスをロックしようとします。ミューテックスが利用できない場合は戻ります (public メンバ関数) | |
| 共有所有権のためにミューテックスをロックしようとします。ミューテックスが 指定されたタイムアウト期間利用できなかった場合は戻ります (public メンバ関数) | |
| 共有所有権のためにミューテックスをロックしようとします。ミューテックスが 指定された時刻まで利用できなかった場合は戻ります (public メンバ関数) | |
| ミューテックスをアンロックします (共有所有権) (public メンバ関数) | |
[編集] 注釈
| 機能テストマクロ | 値 | 規格 | 機能 |
|---|---|---|---|
__cpp_lib_shared_timed_mutex |
201402L |
(C++14) | std::shared_timed_mutex
|
[編集] 例
| このセクションは未完成です 理由: 動機付けとなる例を構築する |
複数のリーダーは扱えるが、ライターは1つしか扱えないリソースを保持するクラスのコピー代入演算子。
このコードを実行
#include <mutex> #include <shared_mutex> class R { mutable std::shared_timed_mutex mut; /* data */ public: R& operator=(const R& other) { // requires exclusive ownership to write to *this std::unique_lock<std::shared_timed_mutex> lhs(mut, std::defer_lock); // requires shared ownership to read from other std::shared_lock<std::shared_timed_mutex> rhs(other.mut, std::defer_lock); std::lock(lhs, rhs); /* assign data */ return *this; } }; int main() { R r; }