操作系统实验报告实验一进程管理
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
}
ArrayList hready = new ArrayList();
ArrayList hblock = 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)
if ((a - jincheng.ra) >= 0 && (b - jincheng.rb) >= 0 && (c - jincheng.rc) >= 0)
{
a = a - jincheng.ra;
b = b - jincheng.rb;
//所需资源 A 的数量
public int rb;
//所需资源 B 的数量
public int rc;
//所需资源 C 的数量
public int ntime; //所需的时间片个数
public int rtime; //已经运行的时间片个数
public char state; // 进程状态, W (等待)、 R(运行)、 B(Βιβλιοθήκη Baidu塞) //public int next;
.
.
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);
3、每个进程可有三个状态(即就绪状态 就绪状态。建立进程就绪队列。
W 、运行状态 R、等待或阻塞状态 B),并假设初始状态为
4、编制进程调度算法:时间片轮转调度算法 本程序用该算法对 n 个进程进行调度,进程每执行一次,
CPU 时间片数加 1,进程还需要的时间片
数减 1。在调度算法中,采用固定时间片(即:每执行一次进程,该进程的执行时间片数为已执行了
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 <= n; i++) {
//a, b,c 分别为 A , B, C 三类资源的总量
//i 为进城计数, i=1 … n //h 为运行的时间片次数, time1Inteval 为时间片大小 (毫秒)
// 对进程进行初始化,建立就绪数组、阻塞数组。 public void input()// 对进程进行初始化,建立就绪队列、阻塞队列 {
.
实验一 进程管理
一、目的
进程调度是处理机管理的核心内容。 本实验要求编写和调试一个简单的进程调度程序。 加深理解有关进程控制块、进程队列的概念,并体会和了解进程调度算法的具体实施办法。
通过本实验
二、实验内容及要求
1、设计进程控制块 PCB 的结构( PCB 结构通常包括以下信息:进程名(进程 ID )、进程优先数、
1
个单位),这时, CPU 时间片数加 1,进程还需要的时间片数减 1,并排列到就绪队列的尾上。
三、实验环境
操作系统环境: Windows 系统。 编程语言: C# 。
四、实验思路和设计
1、程序流程图
.
.
开始
对进程进行初始化,建立就绪队列、阻塞队列。
Input()
触发时钟,调用时间片轮转调度算法。 runFcfs()
轮转时间片、进程所占用的 CPU 时间、进程的状态、当前队列指针等。可根据实验的不同,
PCB 结构
的内容可以作适当的增删) 。为了便于处理,程序中的某进程运行时间以时间片为单位计算。各进程的
轮转时间数以及进程需运行的时间片数的初始值均由用户给定。
2 、 系 统 资 源 ( r1… rw), 共 有 w 类 , 每 类 数 目 为 r1… rw 。 随 机 产 生 n 进 程 Pi( id,s(j,k) , t),0<= i<= n,0<= j <=m,0<=k<=dt 为总运行时间,在运行过程中,会随机申请新的资源。
pcb jincheng = new pcb(); 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;
是 就绪队列为空?
否 输出就绪队列和阻塞队列的信息。 outputall()
结束
取就绪队列的第一个进程,判断其运行的时间片 是否达到所需次数。如果达到,则释放资源 如果没达到,则运行一个时间片。 running()
检查阻塞队列, 对于当前资源数目满足阻塞队列的进程, 由阻塞转入就绪队列。 testblock()
检查是否有新进程产生,如果有,则判断系统资源是否 够用,如果够用,则分配给该进程,插入就绪队列。如 果不够用,则插入阻塞队列。 testnew()
显示三类资源情况。 rescore()
.
.
2、主要程序代码 //PCB 结构体
struct pcb
{
public int id;
//进程 ID
public int ra;