同步关系 :缓冲区未满才能放入,缓冲区未空才能取,某个消费者连续取十件之后其他消费者才能取
互斥关系:所有进程互斥访问缓冲区
也是一个需要立刻写出来的题,不能耽搁
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); //取完十个之后解锁
}
}