生产者和消费者问题实验报告.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文档。上传文档
查看更多
生产者和消费者问题实验报告

实 验 报 告 课程名称: 操作系统 实验名称: 生产者和消费者问题 学 号: 学生姓名: 班 级: 指导教师: 评 分: 实验日期:2012年 10月 22 日 1、实验目的: 掌握基本的同步互斥算法,理解生产者和消费者模型。 了解windows 2000/XP中多线程的并发执行机制,线程间的同步和互斥。 学习使用windows 2000/XP中基本的同步对象,掌握相应的API。 2、实验要求 (1)创建生产和消费线程 在windows2000环境下,创建一个控制台程序,在此进程中创建n个线程来模拟生产者或消费者。这些线程的信息由我们在本程序定义的“测试用例文件”中予以制定。该文件的格式如下: 3 P 3 P 4 C 4 1 P 2 C 3 1 2 4 (2)生产和消费的规则 a.共享缓冲区存在空闲空间时,生产者即可用共享缓冲区。 b.只有当所有的消费者需求都被满足以后,该产品所在的共享缓冲区才能被释放,并作为空闲空间允许心的生产者适用。 c.每个消费者线程的各个消费需求之间存在先后顺序。 d.在每个县城发出读写操作申请、开始读写操作和结束读写操作时分别显示一行提示信息。 3、实验环境 硬件: CPU :AMD QL64 内存: 2GB显卡:ATI 4570硬盘:日立250G 软件:Windows 2000/XP。 开发工具:VC++6.0。 4、实验内容 1)实现原理 a.生产者和消费者模型 b.同步对象 c.CreateThread的用法 功能:本API创建一个在调用进程的地址空间中执行的线程。 格式: HANDLE CreateThread(   LPSECURITY_ATTRIBUTES lpThreadAttributes,   DWORD dwStackSize,   LPTHREAD_START_ROUTINE lpStartAddress,   LPVOID lpParameter,   DWORD dwCreationFlags,   LPDWORD lpThreadId); d.CreateMutex的用法 功能:本API产生一个命名的或者匿名的互斥量对象。 格式: HANDLE CreateMutex(   LPSECURITY_ATTRIBUTESlpMutexAttributes, // 指向安全属性的指针   BOOLbInitialOwner, // 初始化互斥对象的所有者   LPCTSTRlpName?// 指向互斥对象名的指针   );HANDLE CreateSemaphore(   LPSECURITY_ATTRIBUTESlpSemaphoreAttributes, // SD   LONGlInitialCount, // initial count   LONGlMaximumCount, // maximum count   LPCTSTRlpName?// object name   );DWORD WaitForSingleObject(   HANDLE hHandle,   DWORD dwMilliseconds   );VOID InitializeCriticalSection( LPCRITICAL_SECTION lpCriticalSection ); h.ReleaseMutex的用法 功能:用来打开互斥锁,即将互斥量加1,。成功调用则返回0。 格式:BOOL ReleaseMutex ( HANDLE hMutex ); EnterCriticalSection 的用法: 功能:用于等待之的呢过临界区对象的所有权。 格式: VOID EnterCriticalSection(    LPCRITICAL_SECTION lpCriticalSection   );LeaveCriticalSection的用法 功能:释放指定临界区对象的所有权。 格式: VOID LeaveCriticalSection(    LPCRITICAL_SECTION lpCriticalSection   ); (3)打开工程目录下的debug,再打开test.txt,输入实验数据,并保存。 (4)最后在进行编译连接。并把实验结果截图保存。 5、实验测试及分析: 结果分析: 1、在每个程序中坐须先做P(mutex),后做V(mutex),二者

文档评论(0)

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

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

1亿VIP精品文档

相关文档