- 1、本文档共16页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
操作系统实验(第一次) 一、实验内容选择一个调度算法,实现处理器调度。二、实验目的在采用多道程序设计的系统中,往往有若干个进程同时处于就绪状态。当就绪状态进程个数大于处理器数时,就必须依照某种策略来决定哪些进程优先占用处理器。本实验模拟在单处理器情况下处理器调度,帮助学生加深了解处理器调度的工作。三、实验题目第二题:设计一个按时间片轮转法实现处理器调度的程序。[提示](1) 假定系统有五个进程,每一个进程用一个进程控制块PCB 来代表。进程控制块的格式为:进程名时间要求求运行时间优先数状态其中,进程名----作为进程的标识,假设五个进程的进程名分别是Q1,Q2,Q3,Q4,Q5。指针----进程按顺序排成循环队列,用指针指出下一个进程的进程控制块首地址,最后一个进程中的指针指出第一个进程的进程控制块首地址。要求运行时间----假设进程需要运行的单位时间数。已运行时间----假设进程已经运行的单位时间数,初始值为“0”。状态----有两种状态,“就绪”状态和“结束“状态,初始状态都为“就绪“,用“R”表示,当一个进程运行结束后,它的状态变为“结束”,用“E”表示。(2) 每次运行你所设计的处理器调度程序之前,为每个进程任意确定它的“要求运行时间”。(3) 把五个进程按顺序排成循环队列,用指针指出队列连接情况。另用一标志单元记录轮到运行的进程。例如,当前轮到Q2 执行,则有:标志单元k1 k2 k3 k4 k5PCB1 PCB2 PCB3 PCB4 PCB5(4) 处理器调度总是选择标志单元指示的进程运行。由于本实验是模拟处理器调度的功能,所以,对被选中的进程并不实际启动运行,而是执行:已运行时间-1来模拟进程的一次运行,表示进程已经运行过一个单位的时间。请同学们注意:在实际的系统中,当一个进程被选中运行时,必须置上该进程可以运行的时间片值,以及恢复进程的现场,让它占有处理器运行,直到出现等待事件或运行满一个时间片。在这里省去了这些工作,仅用“已运行时间+1”来表示进程已经运行满一个时间片。(5) 进程运行一次后,应把该进程的进程控制块中的指针值送到标志单元,以指示下一个轮到运行的进程。同时,应判断该进程的要求运行时间与已运行时间,若该进程要求运行时间≠已运行时间,则表示它尚未执行结束,应待到下一轮时再运行。若该进程的要求运行时间=已运行时间,则表示它已经执行结束,应把它的状态修改为“结束”(E)且退出队列。此时,应把该进程的进程控制块中的指针值送到前面一个进程的指针位置。(6) 若“就绪”状态的进程队列不为空,则重复上面(4)和(5)的步骤,直到所有进程都成为“结束”状态。(7) 在所设计的称序中应有显示或打印语句,能显示或打印每次被选中进程的进程名以及运行一次后进称对列的变化。(8) 为五个进程任意确定一组“要求运行时间”,启动所设计的处理器调度程序,显示或打印逐次被选中进程的进程名以及进程控制块的动态变化过程。四、实验报告(1) 实验题目。(2) 程序中使用的数据结构及符号说明。(3) 流程图。(4) 打印一份源程序并附上注释。(5) 打印程序运行时的初值和运行结果,要求如下:i 进程控制块的初始状态ii.选中运行的进程名以及选中进程运行后的各进程控制块状态。对于 ii 要求每选中一个进程运行后都要打印。四、流程图实验代码#includeiostream#includestring#includetime.h#includecstdlibusing namespace std;int n;class PCB{public:int pri;//进程优先数int runtime;//进程运行CPU时间int pieceOftime;//轮转时间片string procname;//进程名string state;//进程状态int needOftime;//还需要时间int Counter;PCB * next;};PCB * run = NULL;PCB * ready = NULL;PCB * finish = NULL;PCB * tial = ready;void Dtime(int t);void Prinft(int a){if(a==1){cout进程名称\t优先数\t还需要时间\t已运行时间\t状态:endl;}elsecout进程名称\t已运行时间\t还需要时间\t计数器\t时间片\t状态endl;}void Prinft(int b,PCB * p){if(b==1){coutp-procname\t\tp-pri\tp-needOftime\t\tp-runtime\t\tp-stateendl;}elsecoutp-procname\t\tp-runtime\t\tp-needOftime\t\tp
您可能关注的文档
- 实务第一章土方工程.doc
- 实小二上《语文园地八》.ppt
- 世界名著开头结尾要素.ppt
- 实现全面建成小康社会的目标(优质课件).ppt
- 实施科教兴国战略最近.ppt
- 实用英语508.ppt
- 世界地质公园科普布展中心施工组织设计要素.docx
- 实时图形课程设计报告格式.doc
- 实用细胞培养技术1.ppt
- 实用运筹学习题选详解.doc
- 广东省深圳市龙岗区德琳学校初中部2022-2023学年七年级上学期期中考试英语试题(原卷版+解析).docx
- 广东省珠海市第四中学、立才学校、梅华中学2022-2023学年七年级上学期期中质量检测英语试题(原卷版+解析).docx
- 教科版2024-2025学年六年级科学上册第一单元第4课时《生物细胞》同步练习(含答案).docx
- 牛津沪教版七年级英语上册单元速记•巧练 Unit 7 【单元测试 · 提高卷】.docx
- 牛津沪教版七年级英语上册单元速记•巧练 Unit 5【单元测试 · 基础卷】.docx
- 广东省深圳市南山区太子湾学校2022-2023学年七年级上学期期中考试英语试题(原卷版+解析).docx
- 广东省深圳市南山第二外国语学校(集团)2022-2023学年七年级上学期期中考试英语试题(含听力)(原卷版+解析).docx
- 牛津沪教版七年级英语上册单元速记•巧练 2023-2024学年七年级上学期期末英语全真模拟卷(深圳适用02).docx
- 广东省阳江市江城区2022-2023学年七年级上学期期中考试英语试题(原卷版+解析).docx
- 广东省梅州市梅县区宪梓中学2022-2023学年七年级上学期期中英语试题(原卷版+解析).docx
最近下载
- 【公开课教案】仁爱英语九上Unit4 Topic1 Section A教学设计.pdf
- 南方科技大学科研启动经费管理暂行办法.pdf VIP
- 金融企业会计第三版孟艳琼习题答案.doc
- 师范学院博士人才科研启动经费管理办法.pdf
- 10kV开闭站配电室工程电气监理实施细则.doc
- 二甲医院复审护理需备材料目录.docx VIP
- 八年级家长会优秀课件PPT.ppt
- 2023年历年真题考试:概率论与数理统计(经管类)历年真题汇编(共65题).pdf VIP
- 水建施工管理工作报告(单位工程验收).docx
- Philips 飞利浦Philips Rice Cooker 5000 Series 口感智选 IH 电饭煲 HD4539 21产品支持与说明书 User Manual.pdf
文档评论(0)