版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验一 进程管理一、目的进程调度是处理机管理的核心内容。本实验要求编写和调试一个简单的进程调度程序。通过本实验加深理解有关进程控制块、进程队列的概念,并体会和了解进程调度算法的具体实施办法。二、实验内容及要求1、设计进程控制块PCB的结构(PCB结构通常包括以下信息:进程名(进程ID)、进程优先数、轮转时间片、进程所占用的CPU时间、进程的状态、当前队列指针等。可根据实验的不同,PCB结构的内容可以作适当的增删)。为了便于处理,程序中的某进程运行时间以时间片为单位计算。各进程的轮转时间数以及进程需运行的时间片数的初始值均由用户给定。2、系统资源(r1rw),共有w类,每类数目为r1rw。随 机
2、产生n进程Pi(id,s(j,k),t),0=i=n,0=j=m,0=k=dt为总运行时间,在运行过程中,会随机申请新的资源。3、每个进程可有三个状态(即就绪状态W、运行状态R、等待或阻塞状态B),并假设初始状态为就绪状态。建立进程就绪队列。4、编制进程调度算法:时间片轮转调度算法本程序用该算法对n个进程进行调度,进程每执行一次,CPU时间片数加1,进程还需要的时间片数减1。在调度算法中,采用固定时间片(即:每执行一次进程,该进程的执行时间片数为已执行了1个单位),这时,CPU时间片数加1,进程还需要的时间片数减1,并排列到就绪队列的尾上。三、实验环境操作系统环境:Windows系统。编程语言
3、:C#。四、实验思路和设计1、程序流程图对进程进行初始化,建立就绪队列、阻塞队列。Input()触发时钟,调用时间片轮转调度算法。runFcfs()取就绪队列的第一个进程,判断其运行的时间片是否达到所需次数。如果达到,则释放资源如果没达到,则运行一个时间片。running()输出就绪队列和阻塞队列的信息。outputall()就绪队列为空/检查阻塞队列,对于当前资源数目满足阻塞队列的进程,由阻塞转入就绪队列。testblock()检查是否有新进程产生,如果有,则判断系统资源是否够用,如果够用,则分配给该进程,插入就绪队列。如果不够用,则插入阻塞队列。testnew()显示三类资源情况。resc
4、ore()结束开始是否2、主要程序代码/PCB结构体struct pcb public int id; /进程ID public int ra; /所需资源A的数量 public int rb; /所需资源B的数量 public int rc; /所需资源C的数量 public int ntime; /所需的时间片个数 public int rtime; /已经运行的时间片个数 public char state; /进程状态,W(等待)、R(运行)、B(阻塞) /public int next; ArrayList hready = new ArrayList(); ArrayList hb
5、lock = new ArrayList(); Random random = new Random(); /ArrayList p = new ArrayList(); int m, n, r, a,a1, b,b1, c,c1, h = 0, i = 1, time1Inteval;/m为要模拟的进程个数,n为初始化进程个数 /r为可随机产生的进程数(r=m-n) /a,b,c分别为A,B,C三类资源的总量 /i为进城计数,i=1n /h为运行的时间片次数,time1Inteval为时间片大小(毫秒)/对进程进行初始化,建立就绪数组、阻塞数组。public void input()/对进程
6、进行初始化,建立就绪队列、阻塞队列 m = ; n = ; a = ; b = ; c = ; a1 = a; b1 = b;、 c1 = c; r = m - n; time1Inteval = ; = time1Inteval; for (i = 1; i = 0 & (b - = 0 & (c - = 0) a = a - ; b = b - ; c = c - ; = W; (jincheng);/加入就绪队列 else = B; (jincheng);/加入阻塞队列 当前进程状态: + ; /从数组起始地址开始输出该数组的内容public void disp(ArrayList li
7、st) ArrayList list1 = new ArrayList(); list1 = list; if 0) for (int j = 0; j ; j+) pcb p = (pcb)list1j; + + + + + + + + + + + + + rn); else rnt 该队列中没有进程!rn); /输出就绪数组和阻塞数组的信息public void outputall() ) rn=CPU运行了: + () + 次=rn); *当前就绪队列的信息!*); 进程ID 进程状态 A资源数 B资源数 C资源数 所需时间片 已运行时间片); disp(hready); *当前就阻塞列
8、的信息!*); 进程ID 进程状态 A资源数 B资源数 C资源 所需时间片 已运行时间片); disp(hblock); &/运行就绪数组的头进程,运行一个时间片,轮转一个时间片,时间片轮转调度算法public void running() ArrayList hready1 = new ArrayList(); hready1 = hready; pcb p1 = new pcb(); p1=(pcb)hready10;% =R; = + 1; h=h+1; rn当前正在运行进程ID是: + + rn); rn进程ID 进程状态 A资源数 B资源数 C资源数 所需时间片 已运行时间片rn);
9、 + + + + + + + + + + + ; if = 】 的进程已经完成!rn); a = a + ; b = b + ; c = c + ; (0); else =W; (p1); (0); /检测当前资源数目是否满足阻塞数组里进程的需求public void testblock() & ArrayList hblock1 = new ArrayList(); hblock1 = hblock; for (int m = 0; m = 0) & (b - = 0) & (c - = 0) =W; (p1); a = a - ; b = b - ; c = c - ; ID号为:+ +
10、的进程由阻塞队列转入就绪队列rn); (m); m-; /检测是否有新的进程产生,随机产生新进程public void testnew() int t; if (r0)/r为随机产生的进程数目& t = (9) + 1; if (t = 0 & (b - = 0 & (c - = 0) a = a - ; b = b - ; c = c - ; = W; 进程状态为: + ;| (jincheng);/加入就绪队列 资源满足新进程请求,该进程进入就绪队列rn); else = B; (jincheng);/加入阻塞队列 进程状态为: + ; 资源不满足新进程请求,该进程进入阻塞队列rn); r
11、 = r - 1; /系统三类资源变化情况的显示public void rescore()/系统三类资源变化情况的显示 if (a a1) = (); if (a = 0 & a b1) = (); if (b = 0 & b c1) = (); 、 if (c = 0 & c 0) outputall(); running(); testblock(); testnew(); rescore(); else = false; = (); = (); = (); rnrn); /计时器触发时间片轮转调度算法private void timer1_Tick(object sender, Even
12、tArgs e) runFcfs();/开始模拟按钮单击执行函数private void button1_Click(object sender, EventArgs e) runmain();、 = false; = false; = false; = false; = false; = false; = false; = false; = false; = false; /清除屏幕按钮单击执行函数private void button2_Click(object sender, EventArgs e) = ; = ; = ; = ; = ; = ; = ; = ; = ; = true;
13、 = true; = true; = true; = true; = true; = true; /运行的主函数public void runmain() input(); = true;3、运行界面和运行结果界面中,可以任意设定需要模拟的进程总数(如5),初始化进程个数(如3),还有A、B、C三类资源的总数(如10、10、10)。为了方便显示,还可以设定时间片的长度(如500毫秒)。除此之外,在运行过程中,所有的资源都是随机生成的,并且其中新进程的产生也是随机的,但是产生的进程总数不会多于开始设定的模拟的进程总数,以防止不断产生新进程,程序不断运行。在显示窗口的上方,还会实时显示资源的变化情况,方便对运行的观察。当运行结束后,可以通过工具栏中的显示选项中的保存结果按钮,将结果保存成txt文件格式,方便运行后的结果分析。五、心得体会本次实验,我的任务是设计一个允许n个进程并发运行的进程管理模拟系统。该系统包括有简单的进程控制、同步与通讯机构,系统在运行过程中能显示各进程的状态及有关参数的变化情况,从而观察诸进程的运行过程及系统的管理过程,我是用C#写的,在我的电脑能够运行通过,虽不能尽善尽美,但也基本能实现老师的要求。 两个星期的实验,虽然时间有点短,但我也收获不少,这次实验
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026河南平顶山发展投资控股集团校园招聘备考题库及参考答案详解【培优a卷】
- 2026广东广州民间金融街管理委员会招聘辅助人员1人备考题库带答案详解(培优)
- 2026太平洋财险安庆中支招聘2人备考题库【有一套】附答案详解
- 2026湖南长沙市芙蓉区招聘中学骨干教师10人备考题库【培优a卷】附答案详解
- 2026广西百色市右江区百城社区卫生服务中心招聘公益性岗位2人备考题库带答案详解(轻巧夺冠)
- 2026广东惠州市惠城区马安镇中心幼儿园招聘备考题库及答案详解【名师系列】
- 2026贵州黔西南州政协办公室公益性岗位招聘4人备考题库(历年真题)附答案详解
- 2026浙江嘉兴市海宁市儿童福利院招聘2人备考题库含答案详解ab卷
- 2026上半年四川成都市卫生健康委员会所属部分事业单位招聘166人备考题库(培优b卷)附答案详解
- 2026陕西延安北方医院招聘备考题库含答案详解(能力提升)
- 实习护士第三方协议书
- 《云南教育强省建设规划纲要(2024-2035年)》解读培训
- 评审专家聘任协议书
- 民宿委托经营管理协议合同书
- 2024-2025学年鲁教版(五四学制)(2024)初中英语六年级下册(全册)知识点归纳
- 2025全国市场监督管理法律知识竞赛测试题库(含答案解析)
- 金融企业呆账核销管理办法(2024年)
- 设备验证培训
- 2025年湖北省八市高三(3月)联考政治试卷(含答案详解)
- 《趣味学方言》课件
- GB/T 19973.2-2025医疗产品灭菌微生物学方法第2部分:用于灭菌过程的定义、确认和维护的无菌试验
评论
0/150
提交评论