- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[操作系统概论]实指导书-实验一 进程管理
实验一 进程管理
一、目的
进程调度是处理机管理的核心内容。本实验要求编写和调试一个简单的进程调度程序。通过本实验加深理解有关进程控制块、进程队列的概念,并体会和了解进程调度算法的具体实施办法。
二、实验内容及要求
1、设计进程控制块PCB结构(PCB结构通常包括以下信息:进程名、进程优先数、轮转时间片、进程所占用的CPU时间、进程的状态、当前队列指针等。可根据实验的不同,PCB结构的内容可以作适当的增删)。为了便于处理,程序中的某进程运行时间以时间片为单位计算。各进程的轮转时间数以及进程需运行的时间片数的初始值均由用户给定。
2、系统资源(r1…r),共有类,每类数目为r1…r。随 机产生n进程Pi(id,s(j,k),t),0=i=n,0=j=m,0=k=dt为总运行时间,在运行过程中,会随机申请新的资源。
3、每个进程可有三个状态(即就绪状态、运行状态、等待状态),并假设初始状态为就绪状态。建立进程就绪队列。
4、编制进程调度算法本程序用算法对n个进程进行调度,进程每执行一次,CPU时间片数加1,进程还需要的时间片数减1。在算法中,采用固定时间片(即:每执行一次进程,该进程的执行时间片数为已执行了个单位),这时,CPU时间片数加,进程还需要的时间片数减,并排列到就绪队列的尾上。操作系统环境:Windows或DOS系统。
编程语言:Turbo C、Visual C++、broland ++、Visual Basic、Delphi。
2、主要程序代码
//PCB结构体
struct pcb{
int id; //进程ID
int ra; //所需资源A的数量
int rb; //所需资源B的数量
int rc; //所需资源C的数量
int ntime; //所需的时间片个数
int rtime; //已经运行的时间片个数
char state; //进程状态,W(等待)、R(运行)、B(阻塞)
struct pcb *next;
} *hready=NULL,*hblock=NULL,*p; //hready,hblock分别为指向就绪和阻塞队列
typedef struct pcb PCB;
int m,n,r,a,b,c,h=0,i=1,time1Inteval; //m为要模拟的进程个数,n为初始化进程个数
//r为可随机产生的进程数(r=m-n)
//a,b,c分别为A,B,C三类资源的总量
//i为进城计数,i=1…n
//h为运行的时间片次数,time1Inteval为时间片大小(毫秒)
//将进程插入到队列链尾(包括就绪队列和阻塞队列)
PCB *insert(PCB *head,PCB*pcb) //带两个指针形参:队列指针head和当前进程PCB
{
PCB *pi,*p1;
p1=head;
pi=pcb;
if (head==NULL)
{
head=pi;
pi-next=NULL;
}
else
{
while(p1-next!=NULL)
{p1=p1-next;}
p1-next=pi;
pi-next=NULL;
}
return(head);
}
//对进程进行初始化,建立就绪队列、阻塞队列。
void input()
{
AnsiString str1;
m=StrToInt (Form1-Edit1-Text); //读取要模拟的进程总数给m
n=StrToInt (Form1-Edit2-Text); //读取需初始化进程数给n
a=StrToInt (Form1-Edit3-Text); //读取A类资源的总数给a
b=StrToInt (Form1-Edit4-Text); //读取B类资源的总数给b
c=StrToInt (Form1-Edit5-Text); //读取C类资源的总数给c
time1Inteval=StrToInt(Form1-Edit6-Text); //读取时间片长度给time1Inteval
Form1-Timer1-Interval=time1Inteval;
r=m-n; //计算可随机产生的进程数为r
for(i=1;i=n;i++) //初始化n个进程信息
{
p=getpcb(PCB); // #define getpcb(type) (type*)malloc(sizeof(type))
p-id=i;
str1+= 产生进程ID:;str1+=IntToStr(p-id)
您可能关注的文档
- REUSE_ALVGRID_DISPLAY超详细讲解.doc
- RFC1055_在行线路上传输IP数据报的非标准协议.doc
- Renesas R78L1C 16位MCU开发方案.docx
- RF+jenkin+svn自动化持续集成环境搭建.doc
- RFID技术在广东网固定资产管理中的应用.doc
- RJ必修2化学第四~学业测评(孔诗韵)知识点.docx
- ROUTE Chater 1 6.0 .doc
- RL-QP-01 件控制程序 -6修改.doc
- ROS ADSL双负载均衡+PPPOE服务器教程图文详解.doc
- RouterOS 3.24版本PCC多线负载均衡设置例程.doc
- [无限互联]AFNtworking核心类AFURLConnectionOperation的详解.doc
- [新课标]必修三 四章 第一节 种群的特征[测试卷].doc
- [永鑫财富移民]澳术移民计算机职业申请:ACS 职业评估.docx
- [江苏]会计从业资考试《财经法规与会计职业道德》试题及答案.doc
- [深圳]上半年会计业资格考试《财经法规》试题及答案.doc
- [河南]高层广场工监理实施细则(土建类)_secret.doc
- [湖南]2009年计从业资格考试《财经法规》试题及答案.doc
- [湖南]会计从业资考试《财经法规》试题及答案.doc
- [湖南]会计从业资考试《财经法规》试题及答案)2.doc
- [湖南]廉租房项目筑、电气、给排水消防工程量清单预算(CAD图272张+预算81页).doc
文档评论(0)