生产者与消费者问题的模拟实现.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文档。上传文档
查看更多
生产者与消费者问题的模拟实现

操作系统 课程设计报告 专业 计算机科学与技术 学生姓名 郑伟 班级 BM计算机091 学号 0951401123 指导教师 李先锋 完成日期 2011年12月31日 博雅学院 题目:生产者与消费者问题的模拟实现 一、设计目的学习完操作系统课程后进行的一次全面的综合训练,加深操作系统基础理论和的理解,加强学生的动手能力。设计内容1)概述)2)设计原理3)详细设计) 按回车后截图,开始生产产品,产品数量增加1,缓冲区中产品数量也增加1 当产品数量超过4时则停止生产执行v操作,进行消费者生产线程,即开始消费一个产品,当消费了一个产品时产品数量小于4则将消费者线程惊醒v操作开始 生产者线程,如此循环,当用户按回车后这对所有的线程进行v操作,即停止所有的操作。 分析:生产者线程和消费者线程是2个互斥量,即2个线程只能有一进行操作,生产的产品的数量不能超过4个当小于4时择进行消费者线程。 5)在编写程序的时候要尽可能用全所学到的函数,因为这是检测我们用C语言进行程序设计的能力的重要方式。在编写程序的时候我们不可能一次就成功,往往一个图形要修改甚至是十几次数据才能得到预期的结果。因此在编写程序的时候一定不能急,要耐心地检测输入的数据和输出的结果,在没达到预期目的的情况下,要及时修改数据进行下一次的检测,只有这样才能成功地用C语言编写出需要的程序)参考文献 汤子瀛等.计算机操作系统.西安电子科技大学出版社.200年月计算机操作系统#include windows.h #include iostream const unsigned short SIZE_OF_BUFFER = 20;//有界缓冲区长度 int g_buffer[SIZE_OF_BUFFER];//开辟缓冲区,用数组表示,可以看成是一个循环队列 unsigned short ProductID = 0;//新生产出来的产品的产品号 unsigned short ConsumeID = 0;//被消耗的产品的产品号 unsigned short in = 0;//产品进缓冲区时的缓冲区下标,用于记录生产者的指针位置 unsigned short out = 0;//产品出缓冲区时的缓冲区下标,用于记录消费者的指针位置 bool g_continue = 1;//控制程序运行:1表示继续运行,0表示停止运行 HANDLE g_hMutex;//线程间的互斥信号量 HANDLE g_hFullSemaphore;//资源信号量:缓冲区满 HANDLE g_hEmptySemaphore;//资源信号量:缓冲区空 DWORD WINAPI Producer(LPVOID);//生产者线程 DWORD WINAPI Consumer(LPVOID);//消费者线程 const unsigned short PRODUCERS_COUNT=4;//生产者的个数 const unsigned short CONSUMERS_COUNT=3;//消费者的个数 const unsigned short THREADS_COUNT=PRODUCERS_COUNT+CONSUMERS_COUNT;//总线程数 HANDLE hThreads[PRODUCERS_COUNT];//各线程的handle DWORD producerID[CONSUMERS_COUNT];//生产者线程的标识符 DWORD consumerID[THREADS_COUNT];//消费者线程的标识符 /*----------------------------程序提示信息开始------------------------------*/ void info()//程序提示信息 { std::cout* - - - - - - - - - - - - - - - - - - - - - - - *std::endl; std::cout| 题 目:生产者消费者问题 |std::endl; std::cout| 指导老师 :李先锋 |std::endl; std::cout| 作者:郑伟 |std::endl; std::cout| 代码行数:200+ |std::endl; std::cout| 班 级:BM计算机091 |std::endl; std::cout| 完成日期:2011-12-30

文档评论(0)

小教资源库 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档