欢迎来到天天文库
浏览记录
ID:48302533
大小:334.50 KB
页数:10页
时间:2020-01-16
《实验一进程的创建与撤销》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、实验一:进程创建与撤消一、实验目的1、加深对进程概念的理解和进程创建与撤消算法;2、进一步认识并发执行的实质。二、实验内容本实验完成如下三个层次的任务:(1)系统级—以普通用户身份认识windows的进程管理。通过windows的“任务管理器”观察进程的状态,进行进程的创建、切换和撤销。(2)语言级—以普通程序员身份认识高级语言Java的进程创建与撤销工具。(3)模拟级—以OS设计师身份编程模拟实现进程创建与撤销功能,并在屏幕上观察进程活动的结果。三、实验步骤1、windows的进程管理(1)按ctrl+alt+delete键,弹出windows
2、任务管理器窗口(2)选择相应操作序号,可以创建一个新的进程(3)在创建完一个新的进程后,可以显示出所有已创建进程的详细信息(4)选择相应操作序号,可以通过输入pcbId或pcbGrade来撤销一个进程2、进程创建与撤销工具(1)进程的创建Processp=Runtime.getRuntime().exec("notepad");(2)进程的撤销p.destroy();3、进程创建与撤销的模拟实现(1)总体设计:①数据结构定义:结构体PCB:进程编号,进程名称,进程优先级和进程创建时间,队列按进程创建时间排序。PCB空间就绪队列指针空队列指针②函数
3、进程创建:从PCB空间申请一个空PCB,填入进程参数,插入就绪队列;进程终止:将指定的就绪进程移出就绪队列,插入空队列;就绪队列输出:输出就绪队列中的进程信息,以便观察创建或撤消活动的结果;主函数:调用创建函数、调用终止函数、输出就绪队列;③主界面设计:进程创建、进程撤销、退出程序图1操作主界面④功能测试:从显示出的就绪队列状态,查看操作的正确与否。(2)详细设计:①数据结构定义:结构体PCB:表1PCB结构体表属性类型pcbIdintpcbNameStringpcbGradeintcreateTimeDatePCB空间:是一个能存放十个PCB对
4、象的数组就绪队列指针:定义一整型变量初始值为零空队列指针:定义一整型变量初始值为零,当有进程创建时,加入。②函数设计进程创建示例图图2创建新进程创建多个进程后,可以查看到所有已创建的进程的详细信息,如图。图3查看所有进程用户可以根据pcbId或者pcbGrade来撤销某一个进程,并在撤销成功后,可以看到撤销后剩余的所有进程信息,如图。图4根据pcbId撤销某个进程图5根据pcbGrade撤销某个进程在操作主界面中选择操作3时,可以退出该程序,如图。图6退出程序四、实验总结该程序的主要任务为对windows的进程管理进行相应的模拟和认识。通过对于进
5、行的创建,切换和撤销,已完成我们对于windows进行的初步了解和认识。在编制程序的过程中,我确实遇见了不少的问题,发现其实自己并不强。但是当一个个问题的出现,自己努力并最后解决的时候,心里却悠然产生了一种非常舒服和惬意的感念。因为是自己努力得来的东西,所以无论怎么样都会看着非常开心,非常激动。通过此次试验,我更加了解了关于进程方面的认识。我今后会更加努力,努力学好自己的专业水平。五、附录//实体类#include#include#include#defineSIZE10typedef
6、charQElemType;typedefintIP;typedefintGRADE;typedefstructQNode{//创建PCBQElemTypename;IPid;QElemTypetime;GRADEgrade;structQNode*next;}PCB,*PCBLink;typedefstruct{PCBLinkfront;PCBLinkrear;}LinkQueue;voidInitPCB(QNodePCB){//PCB初始化PCB.grade=0;PCB.id=0;PCB.name='*';PCB.next=NULL;PCB.
7、time='*';}voidInitReadyQueue(LinkQueue&Q){//初始化就绪队列Q.front=Q.rear=(PCBLink)malloc(sizeof(QNode));Q.front->next=NULL;}voidEnQueue(LinkQueue&Q,QNodePCB){//入队PCBLinkp=(PCBLink)malloc(sizeof(QNode));p->id=PCB.id;p->name=PCB.name;p->grade=PCB.grade;p->time=PCB.time;p->next=PCB.nex
8、t;Q.rear->next=p;Q.rear=p;}voidDeNullQueue(LinkQueue&Q){//空队列出队if(Q.
此文档下载收益归作者所有