void count_down(ptrdiff_t update = 1);
概要
ラッチのカウンタ値をupdate
だけ減算し、カウンタ値が0
になれば待機中スレッドのブロック解除を行う。
説明のため、ここではカウンタ値をcounter
と表記する。
事前条件
update >= 0
かつ update <= counter
効果
アトミックにcounter -= update
を実行する。
counter
が0
と等しければ、*this
上で待機中の全スレッドをブロック解除する。
戻り値
なし
例外
この関数は、以下のerror conditionを持つsystem_error
例外オブジェクトを送出する可能性がある:
resource_unavailable_try_again
: 操作対象のネイティブハンドル型が無効operation_not_permitted
: スレッドにこの操作を行う権限がないinvalid_argument
: 実引数が無効
例
#include <iostream>
#include <latch>
#include <thread>
int main()
{
int shared_data = 0;
std::latch stored{1};
std::thread t([&]{
// 通知を待機し、共有データから読取り
stored.wait();
std::cout << shared_data << std::endl;
});
// 共有データへ書込み、通知を行う
shared_data = 42;
stored.count_down();
t.join();
}
出力
42
バージョン
言語
- C++20
処理系
- Clang: 11.0 ✅
- GCC: ??
- ICC: ??
- Visual C++: ??