您所在位置: 网站首页 / 操作系统实验二:进程管理.docx / 文档详情
操作系统实验二:进程管理.docx 立即下载
2025-08-16
约1万字
约19页
0
17KB
举报 版权申诉
预览加载中,请您耐心等待几秒...

操作系统实验二:进程管理.docx

操作系统实验二:进程管理.docx

预览

免费试读已结束,剩余 14 页请下载文档后查看

10 金币

下载文档

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

操作系统实验二:进程管理

篇一:操作系统实验报告实验一进程管理一、目的进程调度是处理机管理的核心内容。本实验要求编写和调试一个简单的进程调度程序。通过本实验加深理解有关进程控制块、进程队列的概念,并体会和了解进程调度算法的具体实施办法。二、实验内容及要求1、设计进程控制块PCB的结构(PCB结构通常包括以下信息:进程名(进程ID)、进程优先数、轮转时间片、进程所占用的CPU时间、进程的状态、当前队列指针等。可根据实验的不同,PCB结构的内容可以作适当的增删)。为了便于处理,程序中的某进程运行时间以时间片为单位计算。各进程的轮转时间数以及进程需运行的时间片数的初始值均由用户给定。2、系统资源(r1…rw),共有w类,每类数目为r1…rw。随机产生n进程Pi(id,s(j,k)t),03、每个进程可有三个状态(即就绪状态W、运行状态R、等待或阻塞状态B),并假设初始状态为就绪状态。建立进程就绪队列。4、编制进程调度算法:时间片轮转调度算法本程序用该算法对n个进程进行调度,进程每执行一次,CPU时间片数加1,进程还需要的时间片数减1。在调度算法中,采用固定时间片(即:每执行一次进程,该进程的执行时间片数为已执行了1个单位),这时,CPU时间片数加1,进程还需要的时间片数减1,并排列到就绪队列的尾上。三、实验环境操作系统环境:Windows系统。编程语言:C#。四、实验思路和设计1、程序流程图2、主要程序代码//PCB结构体structpcb{publicintid;//进程IDpublicintra;//所需资源A的数量publicintrb;//所需资源B的数量publicintrc;//所需资源C的数量publicintntime;//所需的时间片个数publicintrtime;//已经运行的时间片个数publiccharstate;//进程状态,W(等待)、R(运行)、B(阻塞)//publicintnext;}ArrayListhready=newArrayList();ArrayListhblock=newArrayList();Randomrandom=newRandom();//ArrayListp=newArrayList();intm,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=1…n//h为运行的时间片次数,time1Inteval为时间片大小(毫秒)//对进程进行初始化,建立就绪数组、阻塞数组。publicvoidinput()//对进程进行初始化,建立就绪队列、阻塞队列{m=int.Parse(textBox4.Text);n=int.Parse(textBox5.Text);a=int.Parse(textBox6.Text);b=int.Parse(textBox7.Text);c=int.Parse(textBox8.Text);a1=a;b1=b;c1=c;r=m-n;time1Inteval=int.Parse(textBox9.Text);timer1.Interval=time1Inteval;for(i=1;i{pcbjincheng=newpcb();jincheng.id=i;jincheng.ra=(random.Next(a)+1);jincheng.rb=(random.Next(b)+1);jincheng.rc=(random.Next(c)+1);jincheng.ntime=(random.Next(1,5));jincheng.rtime=0;listBox1.Items.Add("产生进程ID:"+jincheng.id);listBox1.Items.Add("所需A资源数目:"+jincheng.ra);listBox1.Items.Add("所需B资源数目:"+jincheng.rb);listBox1.Items.Add("所需C资源数目:"+jincheng.rc);listBox1.Items.Add("所需时间片数:"+jincheng.ntime);if((a-jincheng.ra)>=0&&(b-jincheng.rb)>=0&&(c-jincheng.rc)>=0){a=a-jincheng.ra;b=b-jincheng.rb;c=c-jincheng.rc;jincheng.state='W';hready.Add(jincheng);//加入就绪队列}else{jincheng.state='B';hblock.Add(jincheng);//加入阻塞队列}
查看更多
单篇购买
VIP会员(1亿+VIP文档免费下)

扫码即表示接受《下载须知》

操作系统实验二:进程管理

文档大小:17KB

限时特价:扫码查看

• 请登录后再进行扫码购买
• 使用微信/支付宝扫码注册及付费下载,详阅 用户协议 隐私政策
• 如已在其他页面进行付款,请刷新当前页面重试
• 付费购买成功后,此文档可永久免费下载
全场最划算
12个月
199.0
¥360.0
限时特惠
3个月
69.9
¥90.0
新人专享
1个月
19.9
¥30.0
24个月
398.0
¥720.0
6个月会员
139.9
¥180.0

6亿VIP文档任选,共次下载特权。

已优惠

微信/支付宝扫码完成支付,可开具发票

VIP尽享专属权益

VIP文档免费下载

赠送VIP文档免费下载次数

阅读免打扰

去除文档详情页间广告

专属身份标识

尊贵的VIP专属身份标识

高级客服

一对一高级客服服务

多端互通

电脑端/手机端权益通用