- 1、本文档共21页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
《进程同步与互斥》试验汇报
试验序号:01试验项目名称:进程同步与互斥
学号
姓名
专业、班
试验地点
指导教师
时间
一、试验目的
1、掌握基本的进程同步与互斥算法,理解生产者-消费者问题。
2、学习使用Windows/XP中基本的同步对象,掌握有关API的使用措施。
3、理解Windows/XP中多线程的并发执行机制,实现进程的同步与互斥。
4、设计程序,实现生产者-消费者进程(线程)的同步与互斥;
二、试验环境
Windows/XP+VisualC++6.0
三、试验内容
以生产者-消费者模型为根据,在Windows/XP环境下创立一种控制台进程,在该进程中创立n个线程模拟生产者和消费者,实现进程(线程)的同步与互斥。
四、设计思绪和流程框图
生产者进程的功能:生产东西,供消费者消费;消费者进程的功能:消费生产者生产的东西。生产者生产产品并存入缓冲区供消费者取走使用,消费者从缓冲器内取出产品去消费。在生产者和消费者同步工作时,必须严禁生产者将产品放入已装满的缓冲器
内
内,严禁消费者从空缓冲器内取产品。
生产者进程
消费者进程
五、源程序(含注释)清单
#includewindows.h#includefstream.h#includestdio.h
#includestring
#includeconio.h//定义某些常量;
//本程序容许的最大临界区数;#defineMAX_BUFFER_NUM10
//秒到微秒的乘法因子;
#defineINTE_PERSEC1000
//本程序容许的生产和消费线程的总数;#defineMAX_THREAD_NUM64
//定义一种构造,记录在测试文献中指定的每一种线程的参数structThreadInfo
{
intserial;//线程序列号
charentity;//是P还是C
doubledelay;//线程延迟
intthread_request[MAXTHREAD_NUM];//线程祈求队列
intn_request;//祈求个数
};
//全局变量的定义
//临界区对象的申明,用于管理缓冲区的互斥访问;CRITICAL_SECTIONPC_Critical[MAX_BUFFER_NUM];
intBuffer_Critical[MAX_BUFFER_NUM];//缓冲区申明,用于寄存产品;
HANDLEh_Thread[MAX_THREAD_NUM];//用于存储每个线程句柄的数组;
ThreadInfoThread_Info[MAX_THREAD_NUM];HANDLEempty_semaphore;
HANDLEh_mutex;
DWORDn_Thread=0;
//线程信息数组;//一种信号量;//一种互斥量;
//实际的线程的数目;
DWORDn_Buffer_or_Critical;//实际的缓冲区或者临界区的数
目;
HANDLEh_Semaphore[MAX_THREAD_NUM];//生产者容许消费者开始消费的信号量;
//生产消费及辅助函数的申明voidProduce(void*p);
voidConsume(void*p);
boolIfInOtherRequest(int);intFindProducePositon();
intFindBufferPosition(int);
intmain(void){
//申明所需变量;
DWORDwait_for_all;
ifstreaminFile;
//初始化缓冲区;
for(inti=0;iMAX_BUFFER_NUM;i++)
Buffer_Critical[i]=-1;
//初始化每个线程的祈求队列;
for(intj=0;jMAX_THREAD_NUM;j++){
for(intk=0;kMAX_THREAD_NUM;k++)
Thread_Info[j].thread_request[k
您可能关注的文档
- 《第三节 动量守恒定律》(同步训练)高中物理选择性必修 第一册_粤教版_2024-2025学年.docx
- 《第三章 热力学定律》试卷及答案_高中物理选择性必修第三册_教科版_2024-2025学年.docx
- 《第十三章 原子结构》试卷及答案_高中物理选择性必修第三册_沪科版_2024-2025学年.docx
- 《第一节 电子的发现》(同步训练)高中物理选择性必修第三册_沪科版_2024-2025学年.docx
- 2025年报关员资格深度解析班精华讲义.docx
- 2025年操作系统进程调度策略性能分析报告.docx
- 2025年操作系统进程管理调度策略分析与优化实践报告.docx
- 2025年操作系统进程管理实践解析(1).docx
- 2025年操作系统进程同步机制与互斥策略实践解析.docx
- 2025年操作系统模拟考试专项训练2.docx
最近下载
- 小学数学百分数练习题(易错题).doc VIP
- 2024年法考学霸笔记民法.pdf
- 老旧小区改造监理实施细则.docx VIP
- ch07_accounting_information_system_considine4e_题库答案.docx VIP
- 碾压砼重力坝施工质量控制要点分析(建筑设计及理论论文资料).doc
- 规范《GA533-2012-挡烟垂壁》.pdf
- 心理健康--培训课件.ppt
- LabSOCS实验室无源效率刻度软件中文.pdf
- 《高等工程热力学及传热学》思考题参考答案.doc VIP
- (高清版)B/T 18266.5-2023 体育场所等级的划分 第5部分:滑雪场所星级划分及评定.pdf VIP
文档评论(0)