欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

【操作系统】-同步互斥-【2014真题】-多生产者多消费者

程序员文章站 2022-04-29 17:25:36
同步关系 :缓冲区未满才能放入,缓冲区未空才能取,某个消费者连续取十件之后其他消费者才能取互斥关系:所有进程互斥访问缓冲区也是一个需要立刻写出来的题,不能耽搁semaphore mutex=1;//互斥访问缓冲区semaphore empty=1000;//1000个缓冲区位置semaphore full=0;semaphore consume;//保证某消费者连续取数void producer(){ while(true) { p(empty);.....

【操作系统】-同步互斥-【2014真题】-多生产者多消费者

同步关系 :缓冲区未满才能放入,缓冲区未空才能取,某个消费者连续取十件之后其他消费者才能取

互斥关系:所有进程互斥访问缓冲区

也是一个需要立刻写出来的题,不能耽搁

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