实习七同步机构 作业 .docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实习七同步机构 作业

实习七 同步机构 一、实习内容 模拟实现用同步机构避免发生进程执行时可能出现的与时间有关的错误。 二、实习目的 进程是程序在一个数据集合上运行的过程,进程是并发执行的,也即系统中的多个进程轮流地占用处理器运行。 我们把若干个进程都能进行访问和修改的那些变量称为公共变量。由于进程是并发地执行的,所以,如果对进程访问公共变量不加限制,那么就会产生“与时间有关”的错误,即进程执行后所得到的结果与访问公共变量的时间有关。为了防止这类错误,系统必须要用同步机构来控制进程对公共变量的访问。一般说,同步机构是由若干条原语——同步原语——所组成。本实习要求学生模拟PV操作同步机构的实现,模拟进程的并发执行,了解进程并发执行时同步机构的作用。 三、实习题目 模拟PV操作同步机构,且用PV操作解决生产者——消费者问题。 程序设计 本实习中的程序由三部??组成:初始化程序、处理器调度程序、模拟处理器指令执行程序。各部分程序的功能及相互间的关系由图12-4至图12-7指出。 ? 模拟的指令功 能p (s) 执行P操作原语v (s) 执行V操作原语put B[IN]: =product; IN: = (IN+1) mod 10GET x: =B[out]; out: =(out+1) mod 10produce 输入一个字符放入C中consume 打印或显示x中的字符GOTO L PC: =LNOP 空操作图12-2 模拟的处理器指令 ? 序号生产者程序消费者程序0producep (s2)1p (s1)GET2PUTv (s1)3v (s2)consume4goto 0goto 0图12-3 生产者和消费者程序 ? ·初始化程序:模拟实习的程序从初始化程序入口启动,初始化工作包括对信号量s1、s2赋初值,对生产者、消费者进程的PCB初始化。 ·处理器调度程序:在计算机系统中,进程并发执行时,任一进程占用处理器执行完一条指令后就有可能被打断而让出处理器由其它进程运行。故在模拟系统中也类似处理,每当执行一条模拟的指令后,保护当前进程的现场,让它成为非运行态,由处理器调度程序按随机数再选择一个就绪进程占用处理器运行。 程序如下: #includestdio.h #define size 3 int s1,s2,in,out,i,m=1,x; //信号量s1,s2,生产标志in,消费标志out int b[size]; //数组用来存放产品名称 void produce() //生产者程序 { int j; if(s10) //判断是否可以继续生产 {s1--; //每生产一件产品,p(s1) printf(请输入产品的名称:); scanf(%d,x); b[in]=x; printf(1-继续生产,2-消费\n); in=(in+1)%size; scanf(%d,j); switch(j) { case 1:i=j;break; case 2:i=j;break; default:printf(操作结束);m=0; //其他键入表示结束 } s2++;} else { printf(存储区已满,无法继续生产\n); //当存储区已满时提示;但可进行消费,即当键入消费选项时可以操作 printf(1-生产,2-消费(此时只能进行消费)\n); scanf(%d,j); if(j==2) i=j;} } void consume() //消费者程序 { int j; if(s20) //判断存储区是否为空 { s2--; x=b[out]; printf(取出的产品为:%d\n,x); printf(1-继续生产,2-消费\n); ou

文档评论(0)

qwd513620855 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档