【操作系统】-同步互斥-【2014真题】-多生产者多消费者
程序员文章站
2022-08-10 19:22:53
同步关系 :缓冲区未满才能放入,缓冲区未空才能取,某个消费者连续取十件之后其他消费者才能取互斥关系:所有进程互斥访问缓冲区也是一个需要立刻写出来的题,不能耽搁semaphore mutex=1;//互斥访问缓冲区semaphore empty=1000;//1000个缓冲区位置semaphore full=0;semaphore consume;//保证某消费者连续取数void producer(){ while(true) { p(empty);.....
同步关系 :缓冲区未满才能放入,缓冲区未空才能取,某个消费者连续取十件之后其他消费者才能取
互斥关系:所有进程互斥访问缓冲区
也是一个需要立刻写出来的题,不能耽搁
semaphore mutex=1;//互斥访问缓冲区
semaphore empty=1000;//1000个缓冲区位置
semaphore full=0;
semaphore consume;//保证某消费者连续取数
void producer()
{
while(true)
{
p(empty);
p(mutex);
生产产品并放入缓冲区
v(mutex);
v(full);
}
}
void consumer()
{
while(true)
{
p(consume);
for(int i=0;i<10;i++)//for循环如果不上锁的话,其他消费者的进程也能进来
{
p(full);
p(mutex);
取出产品消费
v(mutex);
v(empty);
}
v(consume); //取完十个之后解锁
}
}
本文地址:https://blog.csdn.net/qq_39328436/article/details/110129761