- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
操作系统试验--读者-写者问题
周俊霞 2011211320
2011211307班
进程同步
实习要求:
本课程实验内容引自《Windows 内核实验教程》(陈向群、林斌等编著,机械工业出版社2002.9)。在Windows 环境下,创建一个包含n 个线程的控制进程。用这n 个线程来表示n个读者或写者。每个线程按相应测试数据文件的要求,进行读写操作。请用信号量机制分别实现读者优先和写者优先的读者-写者问题。
1.读者-写者问题的读写操作限制:
1)写-写互斥;
2)读-写互斥;
3)读-读允许;
2.读者优先的附加限制:如果一个读者申请进行读操作时已有另一读者正在进行读操作,
则该读者可直接开始读操作。
写者优先的附加限制:如果一个读者申请进行读操作时已有另一写者在等待访问共享资
源,则该读者必须等到没有写者处于等待状态后才能开始读操作。
运行结果显示要求:要求在每个线程创建、发出读写操作申请、开始读写操作和结束读写操作时分别显示一行提示信息,以确信所有处理都遵守相应的读写操作限制。
二.测试数据文件格式
测试数据文件包括n 行测试数据,分别描述创建的n 个线程是读者还是写者,以及读写
操作的开始时间和持续时间。每行测试数据包括四个字段,各字段间用空格分隔。第一字段
为一个正整数,表示线程序号。第一字段表示相应线程角色,R 表示读者是,W 表示写者。
第二字段为一个正数,表示读写操作的开始时间。线程创建后,延时相应时间(单位为秒)
后发出对共享资源的读写申请。第三字段为一个正数,表示读写操作的持续时间。当线程读
写申请成功后,开始对共享资源的读写操作,该操作持续相应时间后结束,并释放共享资源。
下面是一个测试数据文件的例子:
1 R 3 5
2 W 4 5
3 R 5 2
4 R 6 5
5 W 5.1 3
三、与实验相关的API 介绍
在本实验中可能涉及的API 有:
线程控制:
CreateThread 完成线程创建,在调用进程的地址空间上创建一个线程,以执行指定的函
数;它的返回值为所创建线程的句柄。
HANDLE CreateThread(
LPSECURITY_ATTRIBUTES lpThreadAttributes, // SD
DWORD dwStackSize, // initial stack size
LPTHREAD_START_ROUTINE lpStartAddress, // thread
function
LPVOID lpParameter, // thread argument
DWORD dwCreationFlags, // creation option
LPDWORD lpThreadId // thread identifier
);
ExitThread 用于结束当前线程。
VOID ExitThread(
DWORD dwExitCode // exit code for this thread
);
Sleep 可在指定的时间内挂起当前线程。
VOID Sleep(
DWORD dwMilliseconds // sleep time
);
信号量控制:
CreateMutex 创建一个互斥对象,返回对象句柄;
HANDLE CreateMutex(
LPSECURITY_ATTRIBUTES lpMutexAttributes, // SD
BOOL bInitialOwner, // initial owner
LPCTSTR lpName // object name
);
OpenMutex 打开并返回一个已存在的互斥对象句柄,用于后续访问;
HANDLE OpenMutex(
DWORD dwDesiredAccess, // access
BOOL bInheritHandle, // inheritance option
LPCTSTR lpName // object name
);
ReleaseMutex 释放对互斥对象的占用,使之成为可用。
BOOL ReleaseMutex(
HANDLE hMutex // handle to mutex
);
WaitForSingleObject 可在指定的时间内等待指定对象为可用状态;
DWORD WaitForSingleObject(
HANDLE hHandle, // handle to object
DWORD dwMilliseconds // tim
您可能关注的文档
- 2016北航招收学历硕士研究生招生简章概述.doc
- 2016初中文言文常见虚词(教师版)概述.doc
- 2016地理会考复习提纲概述.doc
- 2016高考冲刺化学必记知识点大全概述.doc
- 2016高考地理一轮复习备考策略小专题知识点梳理汇总素材概述.doc
- 2016高考化学复习考点3离子反应离子方程式的书写与判断练习概述.doc
- 2016高考语文二轮专题复习专题13散文阅读练习概述.doc
- 2016高考政治四本书易错易混点概述.doc
- 2016高三政治一轮复习课时训练:必修二政治生活第四单元当代国际社会第九课维护世界和平促进共同发展概述.doc
- 2016届福建省高三上学期第一次月考化学试卷(版)概述.doc
文档评论(0)