进程管理_实验报告一流程图..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文档。上传文档
查看更多
进程管理_实验报告一流程图.

实验一 课程名称:操作系统 课程类型:必修 实验项目名称:进程管理 实验题目:短作业优先算法、动态可剥夺优先数算法和基本循环轮转算法。 一、实验目的 进程是操作系统最重要的概念之一,进程调度又是操作系统核心的主要内容。本实验要求学生独立的用高级语言编写和调试一个简单的模拟进程调度的程序。通过本实验,加深学生理解有关进程控制块、进程队列的概念,并体会和了解短作业优先、优先数和时间片轮转调度算法的具体实施办法。 二、实验要求及实验环境 (1) 设计一个有n 个进程的进程调度程序(具体个数可由键盘输入)。每一个进程用一个进程控制块PCB 来代表。PCB 中应包含下列信息:进程名、进程优先数、进程的状态、进程需要运行的时间及利用CPU运行的时间等。进程的个数、各进程的优先数、轮转时间片数以及进程运行需要地时间可由键盘输入。 (2) 调度程序应包含2~3 种不同的调度算法,运行时可任选一种。 (3) 每个进程处于运行Run、就绪ready 和完成Finish 三种状态之一,假定初始状态都为就绪状态ready。(也可没有Finish状态,可以在设计程序时实现处以Finish状态的进程删掉)。 (4)系统能显示各进程状态和参数的变化情况。 (5)动态可剥夺优先数在创建进程时给定一个初始,当进程获得一次cpu后其优先数就减少 三、设计思想 (本程序中的用到的所有数据类型的定义,主程序的流程图及各程序模块之间的调用关系) 1.程序流程图 (见下图) 2.逻辑设计 使用链表表示就绪队列,每个元素包括进程名、进程优先数、进程的状态、进程需要运行的时间及利用CPU运行的时间等信息。 该结构需支持以下操作:取头节点,在表尾插入节点,删除头节点,判断表空。为此,至少引入3 个指针变量:头指针HEAD 和活动指针p、q。 3、物理设计 struct pcb { char name[10]; int priority; int state; int needtime; int runtime; struct pcb *next; }; /*用此结构体来模拟一个进程*/ 开始 选择菜单的选项choice 创建 进程 链表 输出菜单 1 短作业 优先 调度 动态 优先 级调度 循环 轮转 调度 退 出 2 3 4 0 结束 图1-1主程序的流程图 开始 就绪队列 是否为空? 取出执行时间最短的进程 修改该进程的状态为“RUN” 输出运行进程的信息 输出若干就绪进程的信息 从链表中删除运行完的进程 否 是 结束 图1-2短作业优先算法的流程图 图1-3动态可剥夺优先数算法的流程图 结束 Flag=0 FLAG=1; 进程运行状态为“ready” 从链表中删除运行完的进程 否 输出运行进程的信息; 输出若干就绪进程的信息 运行时间加1; 优先级减1。 取出优先级最高的进程; 并修改进程的状态为“RUN” 就绪队列 是否为空? 开始 是 Flag=1? ?? 否 否 是 运行结束否? 是 否 该进程优先级是就绪进程中优先级最大的么? 是 指针r指向就绪队列的最后一个进程 选中就绪队列的第一个进程; 将该进程的状态改为“RUN”; 输出该运行进程的信息。 是 输入时间片 就绪队列 是否为空? 否 时间片内,进程运行结束否 否 运行时间=运行时间+时间片;并输出 输出就绪进程的信息 运行时间=需要时间; 并输出 进程运行结束否 是 删除该进程 否 将该进程移到表尾 是 结束 开始 图1-4循环轮转算法的流程图

文档评论(0)

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

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

1亿VIP精品文档

相关文档