- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)