の使い方にちょっと戸惑いますstd::condition_variable
。を呼び出す前にを作成unique_lock
する必要があることを理解しています。私が見つけられないのは、またはを呼び出す前に一意のロックも取得する必要があるかどうかです。mutex
condition_variable.wait()
notify_one()
notify_all()
cppreference.comの例は矛盾しています。たとえば、notify_one ページには次の例が示されています。
#include <iostream>
#include <condition_variable>
#include <thread>
#include <chrono>
std::condition_variable cv;
std::mutex cv_m;
int i = 0;
bool done = false;
void waits()
{
std::unique_lock<std::mutex> lk(cv_m);
std::cout << "Waiting... \n";
cv.wait(lk, []{return i == 1;});
std::cout << "...finished waiting. i == 1\n";
done = true;
}
void signals()
{
std::this_thread::sleep_for(std::chrono::seconds(1));
std::cout << "Notifying...\n";
cv.notify_one();
std::unique_lock<std::mutex> lk(cv_m);
i = 1;
while (!done) {
lk.unlock();
std::this_thread::sleep_for(std::chrono::seconds(1));
lk.lock();
std::cerr << "Notifying again...\n";
cv.notify_one();
}
}
int main()
{
std::thread t1(waits), t2(signals);
t1.join(); t2.join();
}
ここでは、最初のロックは取得されませんがnotify_one()
、2 番目のロックは取得されnotify_one()
ます。例のある他のページを見ると、ほとんどがロックを取得していないさまざまなことがわかります。
- を呼び出す前にミューテックスをロックすることを自分で選択できます
notify_one()
か? また、なぜロックすることを選択するのでしょうか? - 与えられた例では、なぜ最初の にはロックがなく
notify_one()
、その後の呼び出しにはあるのですか。この例は間違っていますか、それとも何らかの理由がありますか?