- 1、本文档共17页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
模拟PV操作同步机构-且用PV操作解决生产者——消费者问题。
实验四:同步机构实验报告
学院:
专业班级:
姓名:
学号:
一、实验内容:
模拟实现用同步机构避免发生进程执行时可能出现的与时间有关的错误。
二、实验目的:
进程是程序在一个数据集合上运行的过程,进程是并发执行的,也即系统中的多个进程轮流地占用处理器运行。
我们把若干个进程都能进行访问和修改的那些变量称为公共变量。由于进程是并发地执行的,所以,如果对进程访问公共变量不加限制,那么就会产生“与时间有关”的错误,即进程执行后所得到的结果与访问公共变量的时间有关。为了防止这类错误,系统必须要用同步机构来控制进程对公共变量的访问。一般说,同步机构是由若干条原语——同步原语——所组成。本实验要求学生模拟PV操作同步机构的实现,模拟进程的并发执行,了解进程并发执行时同步机构的作用。
三、实验题目:
模拟PV操作同步机构,且用PV操作解决生产者——消费者问题。
四、此次用到的数据结构知识如下:
typedefstructPcb{
charname[10];//进程名
charstate[10];//运行状态
charreason[10];//若阻塞,其原因
intbreakp;//断点保护
structPcb*next;//阻塞时的顺序
进程名
状态
等待原因
断点
后继进程
}Pcb,*link;
进程控制块结构
定义两个进程:linkp1;//生产者进程,linkc1;//消费者进程。pc程序计数器和
linkready;就绪队列,linkb_s1;s1阻塞队列,linkb_s2;s2阻塞队列。
五、实验源代码:
分为四个头文件。
1、a.h头文件代码如下:
#includestring.h
#includectype.h
#includemalloc.h/*malloc()等*/
#includelimits.h/*INT_MAX等*/
#includestdio.h/*EOF(=^Z或F6),NULL*/
#includestdlib.h/*atoi()*/
#includeio.h/*eof()*/
#includemath.h/*floor(),ceil(),abs()*/
#includeprocess.h/*exit()*/
#includeiostream
usingnamespacestd;
#includetime.h
#defineBUF10//缓存的大小
#defineMAX20//最大可以输入的字符
2、b.h头文件代码如下:
//数据结构的定义和全局变量
ready-breakp=pc;//保存断点
}
else{//v(s2)
s2++;
if(s2=0)
wakeup(2);//唤醒消费进程
ready-breakp=pc;//保存断点
}
}
voidblock(ints){//阻塞函数的定义
linkp;
intnum1=0;
intnum2=0;
if(s==1){//生产进程
strcpy(p1-state,Block);//改变状态
strcpy(p1-reason,S1);//说明原因
p=b_s1;
while(p){
num1++;
p=p-next;//p的值为NULL,表示队尾
}
if(!b_s1)
b_s1=p1;
else
p=p1;
p1-next=NULL;
printf(\t*p1生产进程阻塞了!\n);
ready-breakp=pc;//保存断点
ready=ready-next;//在就绪队列中去掉,指向下一个
num1++;
}
else{//消费进程
strcpy(c1-state,Block);
strcpy(c1-reason,S2);
p=b_s2;
while(p){
num2++;
p=p-next;//p的值为NULL,表示队尾
}
if(!b_s2)
b_s2=c1;
else
p=c1;
ready-breakp=pc;//保存断点
ready=ready-next;//在就绪队列中去掉,指向下一个
您可能关注的文档
- 模拟病房呼叫系统.doc
- 楼屋面裂缝的分析和防治措施过程.doc
- 楼型钢悬挑扣件式钢管脚手架技术交底-TJ1---副本.doc
- 模拟2---A题--血管的三维重建论文.doc
- 楼宇低压配电系统的设计.doc
- 模内转印技术(IMD).doc
- 楼宇对讲及门施工方案.doc
- 模内覆膜(IML)注塑产品外观技术要求.doc
- 楼宇对讲施工工艺简介.doc
- 模联基础问题资料.doc
- Unit 6 Get Close to Nauture Lesson 22 -课件-2025-2026学年度北京版英语四年级上册.pptx
- Unit 7 Be Together Lesson 23 -课件-2025-2026学年度北京版英语四年级上册.pptx
- 2025食品饮料行业AI转型白皮书-2025食品饮料行业数智化转型领先实践.pdf
- Unit 7 Be Together Lesson 24 -课件-2025-2026学年度北京版英语四年级上册.pptx
- Unit 7 Be Together Lesson 25 -课件-2025-2026学年度北京版英语四年级上册.pptx
- Unit 7 Be Together Lesson 26 -课件-2025-2026学年度北京版英语四年级上册.pptx
- 2025年广州体育职业技术学院单招职业倾向性考试题库完美版.docx
- 软件公司员工考勤异常处理.doc
- 2025年土地登记代理人之土地登记相关法律知识题库500道及完整答案【有一套】.docx
- 2025年四平职业大学单招职业适应性考试题库含答案.docx
文档评论(0)