操作系统进程互斥实验.docVIP

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

软件学院操作系统实验报告 ? 实验题目:进程互斥实验 学号:201200301043 日期: 2014年5月10日 班级: 2012级软件5班 姓名: 杜肖兵 Email:xiaobing_du2012@163.com 实验目的: 进一步研究和实践操作系统中关于并发进程同步与互斥操作的一些经典问题的解法,加深对于非对称性互斥问题有关概念的理解。观察和体验非对称性互斥问题的并发控制方法。进一步了解Linux 系统中IPC 进程同步工具的用法,训练解决对该类问题的实际编程、调试和分析问题的能力。 硬件环境: Ubuntu11.10 软件环境: bash终端 vi编辑器 实验步骤: 1.掌握终端的基本命令; 2.掌握vi编辑器的接本使用方法; 3.掌握C语言基本语法; 4.掌握示例程序; 5.编写题目要求的代码; 代码分析: 为了让解决这个同步问题,采用共享内存,信号量,消息队列三种IPC同步对象处理。 每一个客户将自己的请求当做条消息发送到相应的消息队列里,通过msgrcv(wait_quest_id,msg_arg,sizeof(msg_arg),0,0)方法接受信息,通过magsnd(wait_respond_id,msg_arg,sizeof(msg_arg),0)方法发送信息;并通过阻塞等待接收消息的方式来等待理发师最终帮自己理发。 设定两个变量 sofa_count,wait_count,每一个客户先判断sofa是不是坐满了,如果sofa_count=4则说明沙发已经坐满了,在判断waitingroom是不是坐满了,如果wait_count13说明waitingroom没有坐满,那就坐在waitingroom,如果waitingroom也坐满了,那么就不能进入理发店;如果sofa_count4则说明沙发没有坐满,那么就直接坐在沙发上;每当一个顾客理发完毕,理发师会从waitingroom张来一个顾客,让他坐在沙发上等待; 理发师查看沙发上有没有人,没有人就睡眠3秒钟,然后再检查沙发上有没有人,如果有人,就到沙发请最先来的客户来理发。 理发师进程通过fork(),创建两个子进程pid1,pid2用来存连个子进程的进程号,加上父进程一共是三个理发师;通过接受和发送消息对客户开始理发;临界区是账本 ,设定信号量semaphore account_sem=1,通过down(account_sem)请求临界区资源,通过UP(account_sem)释放临界区资源;三个理发师的上下文是一样的。 调试过程: online@online-Lenovo:~$ cd dxb online@online-Lenovo:~/dxb$ cd test5 online@online-Lenovo:~/dxb/test5$ make gcc -g -c Barber.c ipc.c Barber.c: In function ‘main’: Barber.c:47:26: error: ‘msg_arg’ undeclared (first use in this function) if(msgrcv(sofa_quest_id,msg_arg,sizeof(msg_arg),0,wait_quest_flg)=0) ^ Barber.c:47:26: note: each undeclared identifier is reported only once for each function it appears in make: *** [Barber.o] 错误 1 online@online-Lenovo:~/dxb/test5$ ^C online@online-Lenovo:~/dxb/test5$ make gcc -g -c Barber.c ipc.c gcc Barber.o ipc.o -o Barber gcc -g -c Customer.c ipc.c Customer.c: In function ‘main’: Customer.c:51:1: error: stray ‘\357’ in program i++; ^ Customer.c:51:1: error: stray ‘\274’ in program Customer.c:51:1: error: stray ‘\233’ in program Customer.c:52:1: error: expected ‘;’ before ‘msg_arg’ msg_arg.mid=i; ^ make: *** [

文档评论(0)

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

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

1亿VIP精品文档

相关文档