博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
用户信号量及其PV操作处理实际问题
阅读量:6318 次
发布时间:2019-06-22

本文共 1034 字,大约阅读时间需要 3 分钟。

P187-43

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/czmn/p/10843269.html

你可能感兴趣的文章
BZOJ3105 [cqoi2013]新Nim游戏
查看>>
困惑的前置操作与后置操作
查看>>
BZOJ 2118 Dijkstra
查看>>
Go语言基础之结构体
查看>>
SpringCloud:Eureka Client项目搭建(Gradle项目)
查看>>
ATL使用IE控件,并且屏蔽右键
查看>>
Jenkins
查看>>
linux下使用screen和ping命令对网络质量进行监控
查看>>
数据库设计技巧
查看>>
css定位概述
查看>>
segment
查看>>
Linux信号 编程
查看>>
python购物车
查看>>
面试/编程
查看>>
打造一个上传图片到图床利器的插件(Mac版 开源)
查看>>
thinkphp判断更新是否成功
查看>>
Do While ... Loop 与 Do Until ... Loop 的区别
查看>>
【Linux】查询某个字符串出现次数
查看>>
高效使用jquery之一:请使用'On'函数
查看>>
ERP环境检测工具设计与实现 Environment Detection
查看>>