读者与写者问题课程设计报告
读者写者实验报告

读者写者实验报告
读者写者问题是指一个共享固定大小缓冲区的进程间通信问题,其中固定大小的缓冲区被多个读者进程和写者进程所共享。
读者进程从缓冲区中读取数据,而写者进程将数据写入缓冲区。
本实验目的是通过使用互斥锁、条件变量和信号量等同步机制,构建一个读者写者问题的解决方案。
实验环境:
- 操作系统:Linux
-编程语言:C语言
实验步骤:
1.创建共享内存缓冲区,用于读者和写者的数据传递。
2.创建互斥锁,用于保护共享内存缓冲区的访问。
3.创建条件变量,用于读者和写者之间的协调。
4.创建读者进程和写者进程,模拟读者写者的并发操作。
5.在读者进程中,通过互斥锁保护共享内存缓冲区,读取数据,并更新计数器。
6.在写者进程中,通过互斥锁保护共享内存缓冲区,写入数据,并更新计数器。
7.使用条件变量实现读者优先或写者优先的策略。
实验结果:
通过实验,我成功实现了读者写者问题的解决方案。
使用互斥锁可以保护共享资源的访问,防止读者和写者同时访问。
使用条件变量可以实现读者优先或写者优先的策略。
实验总结:
通过本次实验,我深入了解了读者写者问题,并且掌握了使用互斥锁、条件变量和信号量等同步机制来解决读者写者问题的方法。
在实现过程中,我遇到了一些困难,例如死锁和竞争条件等问题。
通
过调试和改进代码,我成功解决了这些问题,提高了程序的稳定性和性能。
在以后的工作中,我会更加注重并发编程的实践,提高自己解决问题
的能力。
读者与写者的课程设计

读者与写者的课程设计一、课程目标知识目标:1. 学生能够理解并掌握阅读与写作的基本概念和技巧。
2. 学生能够识别并分析不同文体的特点,如记叙文、说明文和议论文。
3. 学生能够运用所学知识评价和欣赏文本,理解作者的观点和意图。
技能目标:1. 学生能够运用各种阅读策略,提高阅读理解能力和速度。
2. 学生能够运用写作技巧,进行有逻辑、有结构的文章创作。
3. 学生能够通过小组讨论、同伴互评等方式,提高表达和沟通能力。
情感态度价值观目标:1. 培养学生对阅读和写作的兴趣,激发创作潜能。
2. 培养学生合作、探究的学习态度,敢于表达自己的观点和感受。
3. 培养学生尊重他人观点,学会倾听和包容,形成良好的审美观。
课程性质:本课程旨在帮助学生掌握阅读与写作的基本技能,提高语文素养,培养良好的学习习惯和情感态度。
学生特点:六年级学生具有一定的阅读和写作基础,好奇心强,求知欲旺盛,但学习方法、技巧有待提高。
教学要求:结合学生特点,注重启发式教学,以学生为主体,关注个体差异,提高学生的实践能力和创新能力。
通过本课程的学习,使学生具备以下具体学习成果:1. 能够独立阅读并分析不同文体的文章。
2. 能够运用所学技巧进行创意写作,并具备一定的审美能力。
3. 形成主动阅读、乐于分享的学习习惯,具备良好的沟通能力和团队协作精神。
二、教学内容本课程教学内容主要包括以下三个方面:1. 阅读理解:- 教材章节:第三单元“阅读与理解”- 内容列举:文章结构分析、作者观点理解、文章主旨归纳、阅读策略运用等。
2. 写作技巧:- 教材章节:第四单元“写作与表达”- 内容列举:记叙文写作技巧、说明文写作技巧、议论文写作技巧、文章构思与布局等。
3. 语文实践:- 教材章节:第五单元“语文实践活动”- 内容列举:小组讨论、同伴互评、创意写作、阅读分享等。
教学安排和进度:第一周:阅读理解(文章结构分析、阅读策略运用)第二周:阅读理解(作者观点理解、文章主旨归纳)第三周:写作技巧(记叙文写作技巧、文章构思与布局)第四周:写作技巧(说明文写作技巧、议论文写作技巧)第五周:语文实践(小组讨论、同伴互评、创意写作)第六周:语文实践(阅读分享、成果展示)教学内容科学系统,注重培养学生的阅读与写作能力,同时结合实践环节,提高学生的实际操作和创新能力。
操作系统实验-读者写者问题

《计算机操作系统》实验报告题目读者写者问题学院(部)信息学院专业计算机科学与技术班级、学生姓名学号指导教师(签字)一、《二、问题描述一个数据文件或者记录,可以被多个进程共享,我们把只要求读该文件的进程称为“Reader进程”,其他进程则称为“Writer进程”。
允许多个进程同时读一个共享对象,因为读操作不会是数据文件混乱。
但不允许一个Writer进程和其他Reader进程或者Writer进程同时访问共享对象,因为这种访问将会引起混乱。
所谓“读者——写着问题(Reader—Writer Problem)”是指保证一个Writer进程必须与其他进程互斥地访问共享对象的同步问题三、解决问题为实现Reader与Writer进程间在读或写是的互斥而设置了一个互斥的信号量Wmutex。
另外,在设置一个整型变量Readcount表示正在读的进程数目。
由于只要有一个Reader进程在读,便不允许Writer去写。
因此,仅当Readercount=0时,表示尚无Reader进程在读时,Reader进程才需要进行Wait(wmutex)操作。
若Wait(Wmutex)操作成功,Reader 进程便可去读,相应地,做Readcount+1操作。
同理,仅当Reader进程在执行了Readercount-1操作后其值为0时,才执行Signal(Wmutex)操作,以便让Writer进程写。
又因为Readercount是一个可被多个Reader 进程访问的临界资源,因此也应该为它设置一个互斥信号量rmutex。
四、代码实现1、读者优先#include<iostream>#include<>using namespace std;CRITICAL_SECTION rmutex,wmutex;int wr;$int readernum;DWORD WINAPI reader(LPVOID IpParamter){cout<<"读者申请\n";wr++;EnterCriticalSection(&rmutex);if(readernum==0)EnterCriticalSection(&wmutex);readernum++;cout<<"读者进入成功正在读取\n";LeaveCriticalSection(&rmutex);Sleep(2000);—EnterCriticalSection(&rmutex);readernum--;cout<<"读者退出\n";wr--;if(readernum==0)LeaveCriticalSection(&wmutex);LeaveCriticalSection(&rmutex);return 0;}DWORD WINAPI writer(LPVOID PM){cout<<"写者申请\n";&while(wr!=0){}EnterCriticalSection(&wmutex);cout<<"写者已进入正在写入\n";Sleep(500);cout<<"写者退出\n";LeaveCriticalSection(&wmutex);return 0;}int main(){readernum=0;#wr=0;InitializeCriticalSection(&rmutex);InitializeCriticalSection(&wmutex);HANDLE hr[5];//定义读者线程HANDLE hw[5];//定义写者线程//int thnum;int drn=0; //输入的读者个数int dwn=0; //输入的写者个数cout<<"输入读者写者线程 1代表读者 2代表写者 0代表结束"<<endl;int th[10];int num=0;^cin>>th[num];while(th[num]){if(th[num]==1){drn++;}if(th[num]==2){dwn++;}num++;cin>>th[num];}&int hr1=0,hw1=0;for(int j=0;j!=num;j++){if(th[j]==1){hr[hr1]=CreateThread(NULL,0,reader,NULL,0,NULL);hr1++;}if(th[j]==2){hw[hw1]=CreateThread(NULL,0,writer,NULL,0,NULL);hw1++;}}>WaitForMultipleObjects(drn, hr, TRUE, INFINITE);WaitForMultipleObjects(dwn, hw, TRUE, INFINITE);for(int i=0;i!=drn;i++){CloseHandle(hr[i]);}for(int i=0;i!=dwn;i++){CloseHandle(hw[i]);}DeleteCriticalSection(&rmutex);DeleteCriticalSection(&wmutex);return 0;(}2、写者优先#include<iostream>#include<>using namespace std;CRITICAL_SECTION rmutex,wmutex;int ww;int readernum;DWORD WINAPI reader(LPVOID IpParamter){cout<<"读者申请\n";!while(ww!=0){}EnterCriticalSection(&rmutex);if(readernum==0){EnterCriticalSection(&wmutex);}cout<<"读者进入成功正在读取\n";readernum++;LeaveCriticalSection(&rmutex);Sleep(2000);EnterCriticalSection(&rmutex);-readernum--;if(readernum==0)LeaveCriticalSection(&wmutex);cout<<"读者退出\n";LeaveCriticalSection(&rmutex);return 0;}DWORD WINAPI writer(LPVOID PM){ww++;cout<<"写者申请\n";EnterCriticalSection(&wmutex);{cout<<"写者已进入正在写入\n";Sleep(1000);cout<<"写者退出\n";ww--;LeaveCriticalSection(&wmutex);return 0;}int main(){readernum=0;ww=0;InitializeCriticalSection(&rmutex);|InitializeCriticalSection(&wmutex);HANDLE hr[5];//定义读者线程HANDLE hw[5];//定义写者线程int drn=0; //输入的读者个数int dwn=0; //输入的写者个数cout<<"输入读者写者线程 1代表读者 2代表写者 0代表结束"<<endl;int th[10];int num=0;cin>>th[num];while(th[num]){if(th[num]==1){、drn++;}if(th[num]==2){dwn++;}num++;cin>>th[num];}int hr1=0,hw1=0;for(int j=0;j!=num;j++){if(th[j]==1){》hr[hr1]=CreateThread(NULL,0,reader,NULL,0,NULL);Sleep(10);hr1++;}if(th[j]==2){hw[hw1]=CreateThread(NULL,0,writer,NULL,0,NULL);Sleep(10);hw1++;}}WaitForMultipleObjects(drn, hr, TRUE, INFINITE);*WaitForMultipleObjects(dwn, hw, TRUE, INFINITE);for(int i=0;i!=drn;i++){CloseHandle(hr[i]);}for(int i=0;i!=dwn;i++){CloseHandle(hw[i]);}DeleteCriticalSection(&rmutex);DeleteCriticalSection(&wmutex);return 0;}3、执行结果读者优先在读者优先中先两个读者申请,再一个写者申请,再有两个读者申请。
(完整word版)操作系统课程设计-读者写者问题

操作系统课程设计报告一、开题报告(一)该项课程设计的意义;1.更加深入的了解读者写者问题的算法;2.加深对线程,进程的理解;3.加深对“线程同步”概念的理解,理解并应用“信号量机制”;4.熟悉计算机对处理机的管理,了解临界资源的访问方式;5.了解C++中线程的实现方式,研读API。
(二)课程设计的任务多进程/线程编程:读者-写者问题。
●设置两类进程/线程,一类为读者,一类为写者;●随机启动读者或写者;●显示读者或写者执行状态;●随着进程/线程的执行,更新显示;(三)相关原理及算法描述;整体概况:该程序从大体上来分只有两个模块,即“读者优先”和“写者优先”模块.读者优先:如果没有写者正在操作,则读者不需要等待,用一个整型变量readcount记录读者数目,用于确定是否释放读者线程,readcount的初值为0.当线程开始调入时.每个读者准备读. 等待互斥信号,保证对readcount 的访问,修改互斥.即readcount++.而当读者线程进行读操作时,则读者数目减少(readcount--).当readcout=0 时,说明所有的读者都已经读完,离开临界区唤醒写者(LeaveCriticalSection(&RP_Write);), 释放互斥信号(ReleaseMutex(h_Mutex)).还需要一个互斥对象mutex来实现对全局变量Read_count修改时的互斥. 另外,为了实现写-写互斥,需要增加一个临界区对象Write。
当写者发出写请求时,必须申请临界区对象的所有权。
通过这种方法,可以实现读-写互斥,当Read_count=1时(即第一个读者到来时),读者线程也必须申请临界区对象的所有权写者优先:写者优先与读者不同之处在于一旦一个写者到来,它应该尽快对文件进行写操作,如果有一个写者在等待,则新到来的读者不允许进行读操作。
为此应当填加一个整形变量write_count,用于记录正在等待的写者的数目,write_count的初值为0.当线程开始调入时.只允许一个写者准备读. 等待互斥信号,保证对write_count的访问,修改互斥.即write_count++.而当写者线程进行读操作时,则相应写者数目减少(write_count--).当write_count=0 时,说明所有的读者都已经读完,离开临界区唤醒读者,释放互斥信号.为了实现写者优先,应当填加一个临界区对象read,当有写者在写文件或等待时,读者必须阻塞在read上。
读者写者问题实验报告

读者写者问题实验报告1. 引言读者写者问题是操作系统中的经典同步问题,用于研究多线程环境下对共享资源的访问和保护。
在该问题中,有多个读者和写者同时对一个共享资源进行操作,需要保证并发访问时的正确性和效率。
通过本实验,我们将探讨读者写者问题的解决方案,并比较不同算法的性能差异。
2. 实验目标本实验的主要目标是通过实现和比较不同的读者写者问题算法,深入了解并发访问的挑战和解决方案。
具体而言,我们将研究以下几个方面:•设计并实现读者写者问题的解决方案•比较不同算法的性能差异•分析可能的优化策略3. 实验方法我们将使用Python编程语言来实现读者写者问题的解决方案。
在实验过程中,我们将尝试以下几种常见的算法:3.1. 读者优先算法在读者优先算法中,当有读者在访问共享资源时,其他读者可以同时访问,但写者需要等待。
只有当所有读者完成访问后,写者才能获得访问权限。
3.2. 写者优先算法在写者优先算法中,当有写者在访问共享资源时,其他读者和写者都需要等待。
只有当写者完成访问后,其他读者或写者才能获得访问权限。
3.3. 公平算法在公平算法中,读者和写者的访问权限是公平的,先到先得。
无论读者还是写者,都需要按照到达的顺序依次获取访问权限。
4. 实验步骤下面是我们实施实验的具体步骤:4.1. 实现基本的读者写者问题解决方案我们首先实现基本的读者写者问题解决方案,包括读者和写者的线程逻辑和共享资源的访问控制。
我们将使用互斥锁和条件变量来保证并发访问的正确性。
4.2. 实现读者优先算法在已有的基本解决方案的基础上,我们实现读者优先算法。
我们将通过优化访问控制的逻辑来实现读者优先的特性。
4.3. 实现写者优先算法类似地,我们在基本解决方案的基础上实现写者优先算法。
我们将调整访问控制的逻辑,使得写者优先于其他读者和写者。
4.4. 实现公平算法最后,我们实现公平算法。
我们将结合队列和条件变量等技术来确保读者和写者的访问顺序是公平的。
课程设计读者写者问题

课程设计读者写者问题一、教学目标本课程的学习目标包括知识目标、技能目标和情感态度价值观目标。
知识目标要求学生掌握读者写者问题的基本概念和相关原理;技能目标要求学生能够运用所学知识解决实际问题,如设计并发控制算法;情感态度价值观目标要求学生培养团队合作意识,提高解决复杂问题的信心。
教学目标的具体、可衡量性体现在:学生能够准确地描述读者写者问题的定义和特点;能够运用基本的并发控制算法解决读者写者问题;在团队项目中,能够有效地协作,共同完成任务。
二、教学内容根据课程目标,本课程的教学内容主要包括读者写者问题的基本概念、并发控制算法及其应用。
教学大纲按照以下顺序安排:1.读者写者问题的定义、特点及分类;2.基本并发控制算法:锁、信号量、管程等;3.读者写者问题的解决方案及评价;4.实际应用案例分析。
教材选用《计算机操作系统》一书,章节安排与教学大纲相对应。
三、教学方法本课程采用多种教学方法,以激发学生的学习兴趣和主动性。
主要包括:1.讲授法:讲解基本概念、原理和算法;2.讨论法:分组讨论解决方案,促进学生思考;3.案例分析法:分析实际应用案例,提高学生解决实际问题的能力;4.实验法:动手实现并发控制算法,培养实际操作能力。
四、教学资源教学资源包括教材、参考书、多媒体资料和实验设备。
教材《计算机操作系统》提供理论知识;参考书补充拓展相关内容;多媒体资料生动展示原理和算法;实验设备支持学生动手实践。
教学资源的选择和准备旨在支持教学内容和教学方法的实施,丰富学生的学习体验,提高学习效果。
五、教学评估本课程的评估方式包括平时表现、作业、考试等,以全面反映学生的学习成果。
平时表现主要评估学生在课堂讨论、提问等方面的参与度;作业分为课后练习和实验报告,评估学生对知识的掌握和实际操作能力;考试则评估学生对课程知识的全面理解。
评估方式力求客观、公正,确保学生在各个方面的努力和进步都能得到合理的评价。
评估结果将作为学生课程成绩的重要组成部分,以激发学生的学习积极性。
读者-写者问题说明书

《操作系统原理》课程设计任务书题目:读者-写者问题的实现学生姓名:李志旭学号:13740113 班级:_13级软件工程_题目类型:软件工程(R)指导教师:陈文娟、马生菊一、设计目的学生通过该题目的设计过程,掌握读者、写者问题的原理、软件开发方法并提高解决实际问题的能力。
二、设计任务编写程序实现读者优先和写者优先问题:读者-写者问题的读写操作限制(包括读者优先和写者优先)写-写互斥:不能有两个写者同时进行写操作读-写互斥:不能同时有一个线程在读,而另一个线程在写。
读-读允许:可以有一个或多个读者在读。
三、设计要求1.分析设计要求,给出解决方案(要说明设计实现所用的原理、采用的数据结构)。
2.设计合适的测试用例,对得到的运行结果要有分析。
3.设计中遇到的问题,设计的心得体会。
4.文档:课程设计打印文档每个学生一份,并装在统一的资料袋中,资料袋前面要贴有学校统一的资料袋封面。
四、提交的成果1. 课程设计说明书内容包括(1) 封面(学院统一印制);(2) 课程设计任务书;(3) 中文摘要150字;关键词3-5个;(4) 目录;(5) 正文;(设计思想;各模块的伪码算法;函数的调用关系图;测试结果等)(6) 设计总结;(7) 参考文献;(8) 致谢等。
注:每一部分是单独的一章,要另起一页写。
2. 排版要求(1) 所有一级标题为宋体三号加粗(即上面写的2~8部分,单独一行,居中)(2) 所有二级标题为宋体四号加粗(左对齐)(3) 所有三级标题为宋体小四加粗(左对齐)(4) 除标题外所有正文为宋体小四,行间距为固定值22磅,每个段落首行缩进2字符(5) 目录只显示3级标题,目录的最后一项是无序号的“参考文献资料”。
3. 其他要求(班长负责,务必按照以下方式建文件夹)(1) 以班级为单位刻录光盘一张,光盘以班级命名,例如:“10级计算机科学与技术1班”;(2) 光盘内每人一个文件夹,以学号姓名命名——如“10730101 陈映霞”,内容包括任务书、设计文档。
写优先”策略的“读者-写者”问题

采用“写优先”策略的“读者-写者”问题学院计算机科学与技术专业计算机科学与技术学号学生姓名指导教师姓名2014-3-11目录一、设计目的与内容 ................................................ 错误!未定义书签。
(1 )、课程设计的目的 (1)(2 ) 、课程设计的内容 (1)(3 ) 、课程设计的要求 (1)二、算法的基本思想 ................................................ 错误!未定义书签。
三、模块流程图......................................................... 错误!未定义书签。
四、测试结果............................................................. 错误!未定义书签。
五、结论..................................................................... 错误!未定义书签。
六、源程序................................................................. 错误!未定义书签。
一、设计目的与内容(1)课程设计的目的:操作系统课程设计是计算机专业重要的教学环节,它为学生提供了一个既动手又动脑,将课本上的理论知识和实际有机的结合起来,独立分析和解决问题的机会。
●进一步巩固和复习操作系统的基础知识。
●培养学生结构化程序、模块化程序设计的方法和能力。
●提高学生调试程序的技巧和软件设计的能力。
●提高学生分析问题、解决问题以及综合利用C语言进行程序设计的能力。
(2) 课程设计的内容:用高级语言编写和调试一个采用“写优先”策略的“读者—写者”问题的模拟程序。
(3) 课程设计的要求:1.读者与写者至少包括ID、进入内存时间、读写时间三项内容,可在界面上进行输入。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
二、设计思路
在Windows 7 环境下,创建一个包含n 个线程的控制台进程。用这 n 个线程来表示n个读者或写者。每个线程按相应测试数据文件的要 求,进行读写操作。请用信号量机制分别实现读者优先和写者优先的读 者-写者问题。 读者-写者问题的读写操作限制: 读者-写者的读写限制(包括读者优先和写者优先) ⑴写-写互斥,即不能有两个写者同时进行写操作 ⑵读-写互斥,即不能同时有一个读者在读,同时却有一个写者在 写 ⑶读读允许,即可以有2个以上的读者同时读 将所有的读者和所有的写者分别放进两个等待队列中,当读允许时 就让读者队列释放一个或多个读者,当写允许时,释放第一个写者操 作。读者写者问题的定义如下:有一个许多进程共享的数据区,这个数 据区可以是一个文件或者主存的一块空间;有一些只读取这个数据区的 进程(Reader)和一些只往数据区写数据的进程(Writer),此外还需要 满足以下条件:⑴任意多个读进程可以同时读这个文件;⑵一次只有一
第三部分:指导教师评语
第四部分:成绩评定
第五部分:附录(源代码)
#include <windows.h> #include <ctype.h> #include <stdio.h> #include <string.h> #include <stdlib.h> #include <malloc.h> #define MAX_PERSON 100 #define READER 0 //读者 #define WRITER 1 //写者 #define END -1 #define R READER #define W WRITER typedef struct _Person { HANDLE m_hThread;//定义处理线程的句柄 int m_nType;//进程类型(读写) int m_nStartTime;//开始时间 int m_nWorkTime;//运行时间 int m_nID;//进程号 }Person; Person g_Persons[MAX_PERSON]; int g_NumPerson = 0; long g_CurrentTime= 0;//基本时间片数 int g_PersonLists[] = {//进程队列 1, W, 3, 5, 2, W, 16, 5, 3, R, 5, 2, 4, W, 6, 5, 5, R, 4, 3, 6, R, 17,7, END, }; int g_NumOfReading = 0; int g_NumOfWriteRequest = 0;//申请写进程的个数 HANDLE g_hReadSemaphore;//读者信号 HANDLE g_hWriteSemaphore;//写者信号 bool finished = false; //所有的读完成
图2.1读者—写者总体流程框图
三、过程论述
⑴概要设计 程序由两部分组成: ①读者-写者模块:包括系统调用接口,读者-写者活动描述主程 序。系统接口主要功能是通过管道向父进程发送系统调用命令,并读取 父进程送来的返回值。读者-写者活动程序根据临界资源的共享,互斥 原则编制,具体见源程序。 ②主控模块:主控模块实现系统初始化系统调用命令接收与解释执 行,系统调用功能的实现(包括信号量机制),及读者-写者活动过程 记录与显示。 初始化系统环境 建立通信管道 启动读者-写者进程 接收系统调用命令 解释执行
个写进程可以往文件中写;⑶如果一个写进程正在进行操作,禁止任何 读进程度文件。我们需要分两种情况实现该问题: 读优先:要求指一个读者试图进行读操作时,如果这时正有其他读 者在进行操作,他可直接开始读操作,而不需要等待。写优先:一个读 者试图进行读操作时,如果有其他写者在等待进行写操作或正在进行写 操作,他要等待该写者完成写操作后才开始读操作,具体流程如下图 2.1所示。
//bool wfinished = false; //所有的写完成 void CreatePersonList(int *pPersonList); bool CreateReader(int StartTime,int WorkTime,int ID); bool CreateWriter(int StartTime,int WorkTime,int ID); DWORD WINAPI ReaderProc(LPVOID lpParam); DWORD WINAPI WriterProc(LPVOID lpParam); int main() { g_hReadSemaphore = CreateSemaphore(NULL,1,100,NULL); //创建信号灯,当前可用的资源数为1,最大为100 g_hWriteSemaphore = CreateSemaphore(NULL,1,100,NULL); //创建信号灯,当前可用的资源数为1,最大为100 CreatePersonList(g_PersonLists); // Create All the reader and writers printf("Created all the reader and writer\n...\n"); g_CurrentTime = 0; while(true) { g_CurrentTime++; Sleep(300); // 300 ms printf("CurrentTime = %d\n",g_CurrentTime); if(finished) return 0; } // return 0; } void CreatePersonList(int *pPersonLists) { int i=0; int *pList = pPersonLists; bool Ret; while(pList[0] != END) { switch(pList[1]) {
图4.1进程1进入图
图4.2进程1完成图
进程2是R操作,在时间16时进入队列,运行时间是5,在它进入时进 程4占用资源,它等待资源,当4释放时占用资源,具体表现如下图 4.3、图4.4所示;
图4.3进程2进入图
图4.4进程2完成图
进程3是R操作,在时间5时进入队列,运行时间是2,在它进入时进程 1占用资源,它等待资源,当进程1释放资源后,由于读者优先,进程 3,5同时调运资源,具体表现如下图4.5、图4.6所示;
进程5是R操作,在时间4时进入队列,运行时间是3, 在它进入时进 程1占用资源,它等待资源,当进程1释放资源后,由于读者优先,进程 3,5同时调运资源,具体表现如下图4.9、图4.10所示;
图4.9进程5进入图
图4.10进程5完成图
进程6是R操作,在时间17时进入队列,运行时间是7,在它进入时进 程2占用资源,它等待进程2释放后最后调用资源,具体表现如下图4.11 所示。
图4.5进程3进入图
图4.6进程3完成图
进程4是W操作,在时间6时进入队列,运行时间是5,在它进入时进程 1占用资源,它等待资源,当进程1释放资源后,由于读者优先,进程 3,5占用资源,它依然等待,直到进程3,5都结束,具体表现如下图 4.7、图4.8所示;
第二部分:参考文献
1.谭浩强.C++程序设计[M].清华大学出版社,2004 2.汤子瀛. 计算机操作系统[M]. 西安电子科技大学出版社. 2006.9 3.刘振安、刘燕君著.C++程序设计课程设计[M].机械工业出版社,2004 4.[美]Abraham Silberschatz, Peter Baer Galvin, Greg Gagne 著. 郑扣根 译. 操作系 统概念(第六版)[M].高等教育出版社,2004 5.陈向群,向勇 等. Windows操作系统原理(第二版)[M].机械工业出版社,2004
所谓读者写者问题,是指保证一个writer进程必须与其他进程互斥 地访问共享对象的同步问题。 读者写者问题可以这样的描述,有一群写者和一群读者,写者在写 同一本书,读者也在读这本书,多个读者可以同时读这本书,但是,只 能有一个写者在写书,并且,读者必写者优先,也就是说,读者和写者 同时提出请求时,读者优先。当读者提出请求时需要有一个互斥操作, 另外,需要有一个信号量S来当前是否可操作。 信号量机制是支持多道程序的并发操作系统设计中解决资源共享时 进程间的同步与互斥的重要机制,而读者写者问题则是这一机制的一个 经典范例。 与记录型信号量解决读者—写者问题不同,信号量机制它增加了一 个限制,即最多允许RN个读者同时读。为此,又引入了一个信号量L,并 赋予初值为RN,通过执行wait(L,1,1)操作,来控制读者的数目,每 当有一个读者进入时,就要执行wait(L,1,1)操作,使L的值减1。当 有RN个读者进入读后,L便减为0,第RN+1 个读者要进入读时,必然会 因wait(L,1,1)操作失败而堵塞。对利用信号量来解决读者—写者问 题的描述如下: Var RN integer;L,mx:semaphore: =RN,1; Begin Parbegin Reader :begin Repeat Swait(L,1,1); Swait(mx,1,0); Perform reader operation; Ssignal(L,1); Until false; End Writer:begin
图4.11进程6进入图
五、总结
本次操作系统课程设计我们小组完成的是读者写者问题,通过学习 信号量机制,我们对其的同步与互斥机制有了很深掌握并认识到同步与 互斥可以保证在一个时间内只有一个线程对某个资源有控制权。共享资 源包括全局变量、公共数据成员或者句柄等。同步还可以使得有关联交 互作用的代码按一定的顺序执行。 总体来说我认为操作系统这门学科在计算机科学当是中非常重要 的。他将我们学过的编程语言联系起来,可以说是第一次利用C语言利 用windows的API与系统进行“沟通”。 总而言之,这次操作系统的课程设计收获颇丰,复习了许多东西, 也从新学会了许多东西。我想这也许就是课程设计的最终目的吧。