用信号量及其PV操作处理实际问题

P187--43、现有3个生产者P1、P2、P3,他们都要生产橘子汁,每个生产者都已分别购得两种不同的原料,待购齐第三种原料后就可配制成橘子汁装瓶出售。有一供应商能源源不断的供应糖、水、橘子精,但每次只拿出一种原料放入容器中供应给生产者。当容器中有原料时,需要这种原料的生产者可以取走,当容器空时供应商又可放入一种原料。假定:生产者p1已购得糖和水;生产者P2已购得水和橘子精; 生产者P3已购得糖和橘子精; 试用: (1)管程(2)信号量和P、V操作写出供应商和3个生产者之间能正确同步的程序。

Cemaphore empty=1;

橘子精=0;糖=0;水=0;

         Process product(){

               While(true){

                      P(empty);

                      产生一个随机数s;

                     If(s==0) V(橘子精);

                     If(s==1) V(水);

                     If(s==2) V(糖);

              }

        }

       Process P1(){

                Process P2(){

                      Process P3(){

                           While(true){

                                  while(true){

                                         while(true){

                                               P(橘子精); 

                                               P(糖);

                       P(水);

                       取走橘子精;

                         取走糖;

                      取走水;

                        V(empty);

                        V(empty);

                     V(empty);

                  }

                                  }

                            }

                   }

            }

      }

Coend

 

2.IPO问题:有多个输入进程、多个处理进程和多个输出进程。输入进程把数据逐步输入到一个有M个单位缓冲区B1上,经处理进程处理之后放到有N个单位的缓冲区B2上,由输出进程进行输出。

        a.这个问题有哪些进程?进程之间有什么样的制约关系?

        b.用信号量及PV操作写出这些进程之间的同步算法

解:

   a:有输入进程、处理进程、输出进程,进程之间有同步关系。

   b:     semaphore B1;B1=M;        /*B1可用的空缓存区*/

           semaphore B2;B2=N;        /*B2可用的空缓存区*/

           semaphore mutex;mutex=1;           /*同步信号*/

           cobegin

                  process input(){

                          while(true){

                                p(mutex);

                  输入;

                  B1--;

                                v(mutex);

                           }

                    }

                 process chuli(){

                        while(true){

                                p(mutex);

                  处理;

                  B1++;

                                 B2--;

                                v(mutex);

                          }

                    }

                 process output(){

                          while(true){

                                p(mutex);

                  输出;

                  B2++;

                                v(mutex);

                           }

                    } 

  coend

转载于:https://www.cnblogs.com/chenwenchao123/p/10836616.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值