电子科大计算机操作系统实验报告级.docx

上传人:b****3 文档编号:6239017 上传时间:2023-05-09 格式:DOCX 页数:19 大小:232.97KB
下载 相关 举报
电子科大计算机操作系统实验报告级.docx_第1页
第1页 / 共19页
电子科大计算机操作系统实验报告级.docx_第2页
第2页 / 共19页
电子科大计算机操作系统实验报告级.docx_第3页
第3页 / 共19页
电子科大计算机操作系统实验报告级.docx_第4页
第4页 / 共19页
电子科大计算机操作系统实验报告级.docx_第5页
第5页 / 共19页
电子科大计算机操作系统实验报告级.docx_第6页
第6页 / 共19页
电子科大计算机操作系统实验报告级.docx_第7页
第7页 / 共19页
电子科大计算机操作系统实验报告级.docx_第8页
第8页 / 共19页
电子科大计算机操作系统实验报告级.docx_第9页
第9页 / 共19页
电子科大计算机操作系统实验报告级.docx_第10页
第10页 / 共19页
电子科大计算机操作系统实验报告级.docx_第11页
第11页 / 共19页
电子科大计算机操作系统实验报告级.docx_第12页
第12页 / 共19页
电子科大计算机操作系统实验报告级.docx_第13页
第13页 / 共19页
电子科大计算机操作系统实验报告级.docx_第14页
第14页 / 共19页
电子科大计算机操作系统实验报告级.docx_第15页
第15页 / 共19页
电子科大计算机操作系统实验报告级.docx_第16页
第16页 / 共19页
电子科大计算机操作系统实验报告级.docx_第17页
第17页 / 共19页
电子科大计算机操作系统实验报告级.docx_第18页
第18页 / 共19页
电子科大计算机操作系统实验报告级.docx_第19页
第19页 / 共19页
亲,该文档总共19页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

电子科大计算机操作系统实验报告级.docx

《电子科大计算机操作系统实验报告级.docx》由会员分享,可在线阅读,更多相关《电子科大计算机操作系统实验报告级.docx(19页珍藏版)》请在冰点文库上搜索。

电子科大计算机操作系统实验报告级.docx

电子科大计算机操作系统实验报告级

电子科技大学

实验报告

学生姓名:

郫县LBJ学号:

指导老师:

温柔可爱刘杰彦

试验地点:

主楼A2-413试验时间:

4月22日早晨

一、试验室名称:

计算机学院主楼机房

二、试验项目名称:

进程与资源管理

试验分工:

郫县LBJ进程管理设计

郫县小胖子资源管理设计

郫县威斯布鲁克进程调度与时钟中止设计

三、试验课时:

2

四、试验原理:

此处试验原理在指导书上非常丰富,所以不照搬过来,关键写出所要使用到知识点,具体实现过程中原理分析见汇报第八部分“试验步骤”处。

(一)总体设计

系统总体架构如图1所表示,最右边部分为进程与资源管理器,属于操作系统内核功效。

要求能够设计与实现一个简单进程与资源管理器,含有以下功效:

完成进程创建、撤销和进程调度;完成多单元(multi_unit)资源管理;完成资源申请和释放;完成错误检测和定时器中止功效。

图1系统总体结构

(二)Testshell设计

应含有功效:

1、从终端或者测试文件读取命令;

2、将用户需求转换成调度内核函数(即调度进程和资源管理器);

3、在终端或输出文件中显示结果:

如目前运行进程、错误信息等。

(三)进程管理设计

1、进程状态与操作

2、进程控制块结构PCB

3、关键函数:

创建进程、撤销进程

(四)资源管理设计

1、关键数据结构RCB

2、请求资源

3、释放资源

(五)进程调度与时钟中止设计

关键:

使用基于优先级抢占式调度策略,在同一优先级内使用时间片轮转算法。

参考课上ppt:

五、试验目:

设计和实现进程与资源管理,并完成Testshell编写,以建立系统进程管理、调度、资源管理和分配知识体系,从而加深对操作系统进程调度和资源管理功效宏观了解和微观实现技术掌握。

六、试验内容:

设计与实现一个简单进程与资源管理器,要求含有以下功效:

完成进程创建、撤销和进程调度;完成多单元(multi_unit)资源管理;完成资源申请和释放;完成错误检测和定时器中止功效。

经过编写测试脚本(testshell)来完成对进程与资源管理器测试。

七、试验环境(设备、元器件):

Windows7、VisualStudio

八、试验步骤:

(一)系统功效需求分析:

(二)总体框架设计:

1、具体原理和总体工作步骤分析:

首先,经过testshell从测试文件中读入多种命令。

然后,对命令进行分析,将用户需求转换成调度内核函数,也就是说,经过调度进程和资源管理器,实现创建进程、撤销进程、进程调度、对资源进行管理、申请和释放资源、检测错误和定时器中止等功效,从而模拟一个操作系统对进程进行调度和对资源进行管理过程。

最终,在终端或者输出文件中,把一系列操作后结果显示出来,包含目前运行进程、错误信息等。

2、相关方法和算法:

(1)C语言中结构struct,用来实现PCB、RCB等

(2)C语言中指针、链表操作,用来实现将PCB和RCB加入队列尾部、从队列中删除、转移至阻塞队列等操作,以及进程调度实施等。

本试验中我们采取带头结点链表来实现多种操作。

(3)基于优先级调度算法、时间片轮转调度算法、抢占式调度算法综合应用。

3、模块调用关系:

本试验中,我们组共编写了三个头文件(pcb.h、rcb.h、test_shell_data.h)和四个源文件(main.c、pcb.c、rcb.c、test_shell_data.c),所以能够分为主函数设计模块、进程管理设计模块、资源管理设计模块和testshell设计模块。

在主函数模块中,需要调用其她三个模块,如创建进程、展示父子子进程等操作,需要调用进程管理设计模块;调度算法实施、展示多种队列等,需要调用testshell设计模块;

在进程管理设计模块中,像销毁PCB等操作,需要实施对RCB释放,则需调用testshell设计模块;

在资源管理设计模块中,提供部分最小操作,不调用其她模块;

在testshell设计模块中,设计到对资源和进程多种操作,需要调用资源管理设计模块和进程管理设计模块。

(三)进程管理设计模块具体设计(本部分我负责实现)

我们计划是在在进程管理设计模块中,实现相关进程多种最基础结构和操作,具体包含:

实现PCB结构体、PCB链表、PCB子节点链表;

实现对PCB链表初始化、对子节点链表初始化、新建PCB、对PCB链表中进行删除、插入、移除(不free)、从等候和阻塞队列中获取PCB得悉、打印目前PCB父节点、打印目前PCB父节点、打印目前PCB子节点链表、插入子队列尾部、从子队列尾部删除。

1、进程状态与操作

(1)进程状态

共ready/running/blocked三种状态,经过结构struct实现,代码以下:

struct{

intrunning;

intblocked;

intready;

}PCB_STATUS;//定义pcb状态三种情况

(2)进程操作:

在此次试验中,将会读进程进行以下操作,结合这些操作具体内容和所学知识,很轻易考虑到经过链表来实现这些操作。

创建(create):

(none)->ready

撤销(destroy):

running/ready/blocked->(none)

请求资源(Request):

running->blocked(当资源没有时,进程阻塞)

释放资源(Release):

blocked->ready(因申请资源而阻塞进程被唤醒)

时钟中止(Time_out):

running->ready

调度:

ready->running/running->ready

2、关键数据结构实现:

(1)进程控制块结构PCB

进程控制块PCB是进程存在唯一标识,而且常驻内存,进程控制块中有很多信息,在此次试验中,依据我们需求,所设计进程控制块结构以下:

结合试验指导书,我们经过结构struct实现进程控制块结构PCB,包含以下信息:

PID(name)

Other_resources//:

resourcewhichisoccupied

Status:

Type&List//type:

ready,block,running….,//List:

RL(Readylist)orBL(blocklist)

Creation_tree:

Parent/Children

Priority:

0,1,2(Init,User,System)

关键代码及注释以下:

structPCB{//pcb结构体

charname[64];//Pname

unsignedintpid;//Pid

structRCB_LIST*rcb_list;//Otherresources

structPCB_LIST*parent_pcb;//父进程

structCHILD_PCB_LIST*child_pcb;//子进程

intstate;//Type&List

intpriority;//0,1,2

};

(3)实现一个PCB链表,方便后面操作:

structPCB_LIST{//pcb链表

structPCBpcb;

structPCB_LIST*next_pcb;

};

(4)实现PCB子节点链表:

structCHILD_PCB_LIST{//pcb子节点链表

structPCB_LIST*node;

structCHILD_PCB_LIST*next_node;

};

3、关键操作设计实现过程

(1)初始化PCB链表(添加了头结点):

voidinit_pcb_list(structPCB_LIST**list){

if(*list){

return;

}

structPCB_LIST*p=(structPCB_LIST*)malloc(sizeof(structPCB_LIST));

p->next_pcb=NULL;

memset(p,NULL,sizeof(structPCB));

*list=p;

}

(2)初始化子节点链表:

voidinit_child_pcb_list(structCHILD_PCB_LIST**list){

if(*list){

return;

}

structCHILD_PCB_LIST*p=(structCHILD_PCB_LIST*)malloc(sizeof(structCHILD_PCB_LIST));

p->next_node=NULL;

memset(p,NULL,sizeof(structCHILD_PCB_LIST));

*list=p;

}

(3)创建一个新PCB:

structPCB_LIST*create_pcb(char*name,unsignedintpid,intstate,unsignedintpriority,structPCB_LIST*parent_pcb){

structPCBpcb;

strcpy(pcb.name,name,strlen(name));

pcb.pid=pid;

pcb.rcb_list=NULL;

pcb.state=state;

pcb.priority=priority;

pcb.parent_pcb=parent_pcb;

pcb.child_pcb=NULL;

structPCB_LIST*pcb_node=(structPCB_LIST*)malloc(sizeof(structPCB_LIST));

pcb_node->pcb=pcb;

pcb_node->next_pcb=NULL;

returnpcb_node;

}

(4)从PCB链表中进行删除:

voiddestory_from_pcb_list(structPCB_LIST*list,char*name)

{

structPCB_LIST*pr_temp,*temp;

pr_temp=temp=list;

intret=1;

while(temp)

{

if(!

strcmp(name,temp->pcb.name)&&ret)

{

release_resource(temp);

pr_temp=temp=list;

ret=0;

}

if(!

strcmp(name,temp->pcb.name))

{

pr_temp->next_pcb=temp->next_pcb;

free(temp);

return;

}

pr_temp=temp;

temp=temp->next_pcb;

}

}

(5)插入pcb链表:

voidinsert_into_pcb_list(structPCB_LIST**list,structPCB_LIST*node)

{

if(!

*list)

init_pcb_list(list);

structPCB_LIST*pr_temp,*temp;

pr_temp=temp=*list;

while(temp)

{

pr_temp=temp;

temp=temp->next_pcb;

}

pr_temp->next_pcb=node;

}

(5)从PCB链表中移除,并不释放该PCB占用空间:

voiddelete_from_pcb_list(structPCB_LIST*list,char*name)

{

structPCB_LIST*pr_temp,*temp;

pr_temp=temp=list;

while(temp)

{

if(!

strcmp(name,temp->pcb.name))

{

pr_temp->next_pcb=temp->next_pcb;

return;

}

pr_temp=temp;

temp=temp->next_pcb;

}

}

(6)从等候和阻塞队列中获取PCB地址:

structPCB_LIST*get_pcb(char*name)

{

structPCB_LIST*temp;

for(inti=2;i>=0;i--){

temp=READY_LIST[i]->next_pcb;

while(temp){

if(!

strcmp(temp->pcb.name,name))

{

returntemp;

}

temp=temp->next_pcb;

}

}

if(BLOCKED_LIST)

temp=BLOCKED_LIST->next_pcb;

while(temp){

if(!

strcmp(temp->pcb.name,name))

{

returntemp;

}

temp=temp->next_pcb;

}

returnNULL;

}

(7)打印目前PCB父节点

voidshow_pcb_parent(structPCB_LIST*node)

{

printf("%sparentnodeis%s\n",node->pcb.name,node->pcb.parent_pcb->pcb.name);

}

(8)打印目前PCB子节点链表

voidshow_pcb_child(structPCB_LIST*node)

{

printf("%schildis",node->pcb.name);

structCHILD_PCB_LIST*temp=node->pcb.child_pcb;

if(temp)

temp=temp->next_node;

while(temp)

{

printf("-->|%s|",temp->node->pcb.name);

temp=temp->next_node;

}

printf("\n");

}

(9)插入子队列尾部

voidinsert_into_child_pcb_list(structCHILD_PCB_LIST**list,structPCB_LIST*node)

{

if(!

*list)

init_child_pcb_list(list);

structCHILD_PCB_LIST*pr_temp,*temp;

pr_temp=temp=*list;

while(temp)

{

pr_temp=temp;

temp=temp->next_node;

}

structCHILD_PCB_LIST*p=(structCHILD_PCB_LIST*)malloc(sizeof(structCHILD_PCB_LIST));

p->node=node;

p->next_node=NULL;

pr_temp->next_node=p;

}

(10)从子队列尾部进行删除

voiddelete_from_child_pcb_list(structCHILD_PCB_LIST*list,char*name)

{

structCHILD_PCB_LIST*pr_temp,*temp;

if(!

list)

return;

pr_temp=list;

temp=pr_temp->next_node;

while(temp)

{

if(!

strcmp(name,temp->node->pcb.name))

{

pr_temp->next_node=temp->next_node;

return;

}

pr_temp=temp;

temp=temp->next_node;

}

}

(四)其她模块设计(组内其她人设计)

1、Testshell设计

Testshell将调度我们设计进程与资源管理器,从而完成测试,含有以下功效:

(1)从终端或者测试文件读取命令;

(2)将用户需求转换成调度内核函数(即调度进程和资源管理器);

(3)在终端或输出文件中显示结果:

如目前运行进程、错误信息等。

2、资源管理设计

与进程管理设计思绪和步骤相同,首先是设计好各类数据结构,包含RCB结构体、RCB等候队列链表、系统RCB结构体、系统RCB链表、RCB链表。

以后是实现好各类与RCB相关基础操作,包含初始化前面设计多种链表、新建RCB,以及对链表进行插入、删除、移除等操作,还有显示RCB队列操作。

3、试验进程调度与时钟中止设计

关键思想即时间片轮转调度算法、优先级调度算法、抢占式算法综合应用,设计到对前面各模块调用。

九、试验数据及结果分析:

将试验指导书中给出测试命令放到测试文件test.txt中,程序从该文件读取命令,并将实施结果输出到屏幕,以下图所表示:

上图结果与试验指导书中给出预期输出结果是一致,说明试验成功。

具体结果分析:

为了更易于观察,我们能够注释掉读文件操作,让程序从键盘输入读取命令,每步命令解释及相关实施结果截图以下:

crx1//创建优先级为1进程x,应显示“*thexisrunning”

crp1//创建优先级为1进程p,应显示“*thexisrunning”

crq1//创建优先级为1进程q,应显示“*thexisrunning”

crr1//创建优先级为1进程r,应显示“*thexisrunning”

经过以上四条指令,就绪队列中优先级1队列中应依次为x、p、q、r,可用资源数应该都是总资源数,实施结果、就绪队列、资源队列情况见下图:

to//一个时间片结束,应去实施p,显示“*thepisrunning”

同时,x进程PCB将进入优先级为0就绪队列,以下图:

req21//为目前进程x申请1个R2资源,显示不变

输出显示不变,不过可用资源数目会发生改变,以下图:

to//一个时间片结束,应去实施q,显示“*theqisrunning”

reqR33//为目前进程q申请3个R3资源,显示不变

过程中截图以下,可用资源数目深入减小:

to//一个时间片结束,应去实施r,显示“*therisrunning”

reqR43//为目前进程x申请3个R4资源,显示不变

to//一个时间片结束,应去实施优先级为0就绪队列中第一个进程x,显示“*thexisrunning”

to指令后截图以下,包含此时就绪队列情况,全部进程PCB都在优先级为0就绪队列中:

to//一个时间片结束,应去实施p,显示“*thepisrunning”,x移到优先级0就绪队列结尾

新优先级为0就绪队列截图以下:

下面两条指令分别为目前进程申请资源,申请不到足够资源,对应进程则会进入阻塞队列。

reqR31//p申请1个R3,但R3已经全部给了q,所以p被阻塞,进入阻塞队列,目前转去实施原来在p后q进程,显示“*theqisrunning”

显示及阻塞队列以下:

reqR42//q申请2个R4,但R4已经只剩下1个,所以q被阻塞,进入阻塞队列,目前转去实施原来在q后r进程,显示“*therisrunning”

reqR22//r申请2个R2,但R2已经只剩下1个,所以r被阻塞,进入阻塞队列,目前转去实施原来在r后x进程,显示“*thexisrunning”

以上两步过后,阻塞队列及就绪队列截图以下:

to//一个时间片结束,就绪队列中只有x,所以仍然实施x,显示“*thexisrunning”

deq//撤销q进程,将释放q进程占用3个R3资源,前面因为申请不到R3资源而被阻塞p进程将重新回到就绪队列,位于x后面,显示不变

to//一个时间片结束,应去实施p,显示“*thepisrunning”

to//一个时间片结束,应去实施x,显示“*thexisrunning”

经过以上四条指令,就绪队列中优先级0队列中应依次为x、p,阻塞队列中应该只有r,以下图:

至此,具体每步分析完成,试验成功。

十、试验结论:

此次试验过程中,我组组员分工明确,在熟练掌握课堂知识基础上,使用c语言模拟了操作系统对进程和资源管理,成功地实现了基于优先级和时间片轮转抢占式调度算法,试验结果与预期相同,很好地完成了此次试验

十一、总结及心得体会:

(1)链表、指针掌握和应用十分关键;

(2)将总任务划分成各个模块,实现各个模块后再总体实现,能够提升效率;

(3)在程序中增加部分犯错处理提醒信息,有利于提升调试过程效率。

十二、对本试验过程及方法、手段改善提议:

能够增加难度更大功效,如模拟进程中止后,返回断点继续实施等。

汇报评分:

指导老师签字:

 

电子科技大学

实验报告

学生姓名:

郫县LBJ学号:

指导老师:

温柔可爱刘杰彦

试验地点:

主楼A2-413试验时间:

6月2日

一、试验室名称:

计算机学院主楼机房

二、试验项目名称:

内存地址转化试验

三、试验课时:

2

四、试验原理:

(一)逻辑地址到线性地址转换

1、逻辑地址、段标识符、索引号、GDT、LDT、T1字段、段描述符、Base字段、线性地址等概念;

2、GDTR、LDTR等相关寄存器知识;

(以上两条在试验指导书中很具体,篇幅较长,不做粘贴了)

3、逻辑地址到线性地址转换过程

从逻辑地址到线性地址转换过程,以下图所表示(以T1=1为例,此时从段选择符中分离出段描述符和T1字段,T1=1,表明段描述符存放在LDT中);

(1)从GDTR中取得GDT地址,从LDTR中取得LDT在GDT中偏移量,查找GDT,从中获取LDT起始地址;

(2)从DS中高13位获取DS段在L

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 小学教育 > 语文

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2