收藏 分销(赏)

操作系统pcb的组织与维护实验.doc

上传人:快乐****生活 文档编号:1796413 上传时间:2024-05-09 格式:DOC 页数:14 大小:90KB
下载 相关 举报
操作系统pcb的组织与维护实验.doc_第1页
第1页 / 共14页
操作系统pcb的组织与维护实验.doc_第2页
第2页 / 共14页
操作系统pcb的组织与维护实验.doc_第3页
第3页 / 共14页
操作系统pcb的组织与维护实验.doc_第4页
第4页 / 共14页
操作系统pcb的组织与维护实验.doc_第5页
第5页 / 共14页
点击查看更多>>
资源描述

1、*大学计算机科学系实 验 报 告 书实验题目: pcb的组织与维护课程名称: 操作系统 主讲教师: 辅导教师: 课程编号: 班 级: 实验时间: 一、 实验目的:1、通过编写和调试pcb组织与维护的模拟程序以加深对pcb组织与维护方案的理解。2、通过编写和调试pcb组织与维护的模拟程序以加强对进程的基本情况以及进程的运行变化过程的进一步理解。 二、 实验环境:VC 6.0+三、 实验内容1、通过线性方式对以pcb为唯一标志的进程进行创建、查询、添加、删除等操作。2、通过索引方式对以pcb为唯一标志的进程进行创建、查询、添加、删除等操作。3、通过链接方式对以pcb为唯一标志的进程进行创建、查询、

2、添加、删除等操作。四、 实验设计原理1、 系统利用PCB来描述进程的基本情况以及进程的运行变化过程。PCB是进程存在的唯一标志,当系统创建一个进程时,为进程设置一个PCB,再利用PCB对进程进行管理和控制。撤销进程时,系统收回它的PCB,进程也随之消亡。进程是由程序、数据和进程控制块PCB三部分组成.PCB是进程的“灵魂”,由于进程控制块中保存了进程的地址信息,通过PCB可以得到进程程序的存储位置,也可以找到整个进程。2、 为了便于管理,系统把所有的PCB用适当方式组织起来。一般来说,大致有以下三种组织方式:1、线性方式;2、索引方式;3、连接方式。通过这三种方式的组织进而对进程进行高效的管理

3、。五、 算法设计与流程程序设计流程图如下:1、 线性方式流程图:否是是是否否是开始读入选择选择输入输入是否是1 否线性方式是否是2索引方式输出:输入有误!请重新输入请输入进程的个数读入进程的个数n保存这n个进程的信息,并创建n个进程选择相应的操作查询添加删除返回首菜单在已有的进程信息中查找对应进程号的进程信息是否存在输出进程信息无该进程把新的进程信息保存在已有的进程信息中查找对应进程号的进程信息是否存在删除该进程无该进程线性方式代码:#include #include using namespace std;#define FALSE 0#define TRUE 1#define TASK_R

4、EADY 3#define TASK_WAITE 4#define TASK_RUNNING 5struct task_structstring pname; /进程名int pid;/进程号int state;/进程当前状态/*3 就绪状态 4 等待状态 5运行状态*/task_struct *next;/指向下一个的;/void showInput();void menu(task_struct *pcb);/int inputNum()/提示输入进程数int n;coutn;coutnext=NULL;task_struct *p=new task_struct;p=pcb;for(in

5、t i=0;ipid=i+1;cout请输入第i+1q-pname;loop:couttmp;if(tmp!=3&tmp!=4&tmp!=5)cout输入错误!state=tmp;if(p-next=NULL)q-next=NULL;p-next=q;/p=q;coutAdd a nodenext=NULL;p=p-next;p-next=q;/p=q;coutfor Addendl;coutendl;void display(task_struct *pcb)task_struct *p;cout*endl;cout进程号t进程名t当前状态next;p!=NULL;p=p-next)cout

6、pidtpnamestate)case 3:coutTASK_READYendl;break;case 4:coutTASK_WAITEendl;break;case 5:coutTASK_RUNNINGendl;break;cout*endl;menu(pcb);/void output(task_struct *pcb, task_struct *p)/输入单个进程记录信息cout*endl;cout进程号t进程名t当前状态endl;coutpidtpnamestate)case 3:coutTASK_READYendl;break;case 4:coutTASK_WAITEendl;br

7、eak;case 5:coutTASK_RUNNINGendl;break; coutendlendlendlendlendl;menu(pcb);void Query(task_struct *pcb)/查询int pid;coutpid;task_struct *p;for(p=pcb-next;p!=NULL;p=p-next)if(p-pid=pid)output(pcb, p);return;cout无该进程!next!=NULL;q=q-next);/if(q-next=NULL)if(pcb-next=NULL)p-pid=1;elsep-pid=q-pid+1;coutp-pn

8、ame;loop1:couttmp;if(tmp!=3&tmp!=4&tmp!=5)cout输入错误!state=tmp;p-next=NULL;/if(q-next=NULL)if(pcb-next=NULL)pcb-next=p;elseq-next=p;coutendlendl;display(pcb);void Delete(task_struct *pcb)/删除task_struct *p,*q;couttmp;for(p=pcb;p!=NULL;p=p-next)q=p-next;if(q-pid=tmp)p-next=q-next;delete q;display(pcb);c

9、out无该进程!next!=NULL)q=p-next;p-next=q-next;delete q;delete pcb;void menu(task_struct *pcb)/提示选择相应的操作int m;cout1. 查询endl;cout2. 添加endl;cout3. 删除endl;cout4. 返回首菜单endl;coutm;coutendlendl;switch(m)case 1:Query(pcb);break;case 2:Add(pcb);break;case 3:Delete(pcb);break;case 4:Destroy(pcb);showInput();break

10、;default:cout输入有误!重新输入endl;menu(pcb); void List()/线性方式int n=inputNum();task_struct *pcb=new task_struct;CreateList(pcb,n);coutendlendlendlendlendlendlendlendlendlendl;display(pcb);void Hash()/索引方式/int n=inputNum();void showInput() /提示选择输入int tmp;cout1. 线性方式endl;/cout2. 索引方式endl;couttmp;coutendlendl;

11、switch(tmp)case 1:List();break;/case 2:Hash();break;default:cout输入有误!请重新输入。endlendl;showInput();void main()showInput();六、实验调试与结果分析(问题的发现、分析、解决方案与创新)实验结果展示:*进程号 进程名 当前状态1 a TASK_WAITE2 s TASK_READY3 d TASK_RUNNING*1. 查询2. 添加3. 删除4. 返回首菜单选择:请输入要查询的进程号:2*进程号 进程名 当前状态2 s TASK_READY1. 查询2. 添加3. 删除4. 返回首菜单选择:选择:2请输入要添加的进程名:f请输入进程状态(3为就绪状态,4为等待,5为运行):5*进程号 进程名 当前状态1 a TASK_WAITE2 s TASK_READY3 d TASK_RUNNING4 f TASK_RUNNING*1. 查询2. 添加3. 删除4. 返回首菜单选择:选择:3请输入要删除的进程号:2*进程号 进程名 当前状态1 a TASK_WAITE3 d TASK_RUNNING4 f TASK_RUNNING*1. 查询2. 添加3. 删除4. 返回首菜单选择:选择:41. 线性方式2. 索引方式请输入你的选择:14

展开阅读全文
部分上传会员的收益排行 01、路***(¥15400+),02、曲****(¥15300+),
03、wei****016(¥13200+),04、大***流(¥12600+),
05、Fis****915(¥4200+),06、h****i(¥4100+),
07、Q**(¥3400+),08、自******点(¥2400+),
09、h*****x(¥1400+),10、c****e(¥1100+),
11、be*****ha(¥800+),12、13********8(¥800+)。
相似文档                                   自信AI助手自信AI助手
百度文库年卡

猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 包罗万象 > 大杂烩

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服