dimanche 5 avril 2015

Condition Variable notify_one notify_all

I'm trying to learn the condition variables, and I'm stuck at the following example. I thought notify_one on consumers should unlock only one waiting consumer, and after repeated start it seems to me that it is not.I've changed notify one into notify all notify_all and also have not noticed a change in behavior. After producer makes notify_one on consumers on screen print GET more then one consumer.Why is this happening?



#include <iostream> // std::cout
#include <thread> // std::thread
#include <mutex> // std::mutex, std::unique_lock
#include <condition_variable> // std::condition_variable
#include <chrono>
std::mutex mtx;
std::condition_variable produce,consume;

int cargo = 0; // shared value by producers and consumers

void consumer () {
std::unique_lock<std::mutex> lck(mtx);
while (cargo==0) consume.wait(lck);
std::cout << "Get" << cargo << " "<< std::this_thread::get_id() << '\n';
cargo--;
produce.notify_one();
}

void producer (int id) {
std::unique_lock<std::mutex> lck(mtx);
while (cargo!=0) produce.wait(lck);
std::cout << "Push" << id << " "<< std::this_thread::get_id() << '\n';
cargo += id;
consume.notify_one();
}

void c () {
while(1) {
consumer();
std::this_thread::sleep_for(std::chrono::milliseconds(1000));
}
}
void p(int n) {
while(1) {
producer(n);
std::this_thread::sleep_for(std::chrono::milliseconds(1000));
}
}

int main ()
{
std::thread consumers[5],producers[5];

for (int i=0; i<5; ++i) {
consumers[i] = std::thread(c);
producers[i] = std::thread(p,i+1);
}

for (int i=0; i<5; ++i) {
producers[i].join();
consumers[i].join();
}

return 0;
}

Aucun commentaire:

Enregistrer un commentaire