



下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1.基本信息实践题目:Peterson算法解决临界问题A完成人:班级:07062301姓名:陈杨学号:0706230101报告日期:2011年1月5日实践内容简要描述实践目标理解临界区问题掌握Peterson算法以解决临界区问题实践内容协作线程兄弟问题设置竞争条件:定义两个全局变量:accntl和accnt2,初值都为零;创建两个线程acc1和acc2;(1)获得一个随机数(2)从accnt1减去这个随机数;(3)将这个随机数加到accnt2中;(4)正确的话,accnt1+accnt2=0;(5)但在未实现线程互斥的情况下,accnt1+accnt2可能不为0。用软件方法实现协作线程,以解决
2、以上临界区问题兄弟问题。可采用Peterson算法或Dekker算法。设计思路利用Peterson算法,实现线程间的互斥。booleanflag2;初值falseintturn;doflagi:=true;turn=j;while(flagjandturn=j);临界区;flagi=false;剩余区;while(1);i为线程自身的序号减去1,j为2减去该线程的序号。当某一进程试图访问临界区时,若另一进程已在访问临界区,则该线程通过循环等待直至另一线程退出临界区方可执行。主要数据结构typedefstructBrotherInfointmiSerial;DWORDmdwDelay;BROTH
3、ERINFO,*PBROTHERINFO;volatileintgiAccnt1=0;/*Ensurevariableinthememory*/volatileintgiAccnt2=0;boolflag2=false,false;intturn;主要代码结构及分析/threadDWORDWINAPIBrother(LPVOIDlpParam)intiLoan,iAccnt,iCounter=0;PBROTHERINFOpThreadInfo;/getinfofromparampThreadInfo=(PBROTHERINFO)lpParam;srand(unsigned)pThreadInf
4、o-mdwDelay);dofprintf(stdout,Iamthread%d,Iamdoing%05dthstepn,pThreadInfo-miSerial,iCounter);iLoan=rand();/*fprintf(stdout,rand_num=%05dn,iLoan);*/Sleep(pThreadInfo-mdwDelay*INTE_PER_SEC);flagpThreadInfo-miSerial-1=true;turn=2-pThreadInfo-miSerial;while(flag2-pThreadInfo-miSerial&turn=2-pThreadInfo-m
5、iSerial);/startofcritical_sectiongiAccnt1=giAccnt1-iLoan;Sleep(pThreadInfo-mdwDelay*INTE_PER_SEC);giAccnt2=giAccnt2+iLoan;iAccnt=giAccnt1+giAccnt2;/endofcritical_sectionflagpThreadInfo-miSerial-1=false;iCounter+;while(iAccnt=0)&(iCountermiSerial-1,j可对应2-pThreadInfo-miSerial。该问题顺利解决。3、一开始我是将sm6.dat直接拷贝到ex2文件夹下,结果在连接程序时出现错误。后来我发现dat文件是执行程序时自动生成的。一开始生成的是空白文件,只需将其以记事本方式打开,即可写入测试数据。实践体会和收获通过此次实验,我基本了解了线程的创建及运行过程。我觉得此次实验中我最大的成就感来自于我通过自身的努力弄懂了临界区问题的产生原因及Peterson算法,并真正做到了活学活用。5.参考文献1汤子瀛著.计算机操作系统(修订版)M.西安:西安电子科技大学出版社.
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 交通协管员就业合同
- 浙江工业大学之江学院《医用物理学》2023-2024学年第二学期期末试卷
- 新疆艺术学院《日语会话Ⅱ》2023-2024学年第二学期期末试卷
- 三亚学院《信息与网络安全》2023-2024学年第二学期期末试卷
- 浙江省富阳二中2025年高三教学调研(二)物理试题试卷含解析
- 苏州高博软件技术职业学院《酒店服务心理学》2023-2024学年第二学期期末试卷
- 江苏省苏州昆山市2025届初三6月热身考化学试题含解析
- 长沙理工大学《生理学A》2023-2024学年第二学期期末试卷
- 三方合同共建企业的协议2025
- 江西省吉安市四校联考2025年高三下学期期末调研测试语文试题含解析
- 工商企业管理毕业论文范文(4篇)
- 浙江省杭州市(2024年-2025年小学三年级语文)人教版开学考试(上学期)试卷(含答案)
- VDA6.3 2023 过程审核检查表-参考表单
- 【网络谣言型寻衅滋事罪的认定存在的争议探析8600字(论文)】
- 2024延迟退休政策详解
- IC反应器的设计11
- IEEE-30节点全套数据2
- 数学-山东省名校考试联盟2023-2024学年高一下学期5月期中检测试题和答案
- 敦煌的艺术-知到答案、智慧树答案
- 2024糖尿病酮症酸中毒诊断和治疗课件
- 妊娠期糖尿病产后护理
评论
0/150
提交评论