实验一进程创建模拟报告材料.doc
《实验一进程创建模拟报告材料.doc》由会员分享,可在线阅读,更多相关《实验一进程创建模拟报告材料.doc(12页珍藏版)》请在课桌文档上搜索。
1、word实验一 进程创建模拟实验学时:2实验类型:验证实验要求:必修一、实验目的1 理解进程创建相关理论;2 掌握进程创建方法;3 掌握进程相关数据结构。二、实验容本实验针对操作系统中进程创建相关理论进展实验。要验者输入实验指导书提供的代码并进展测试。代码简化了进程创建的多个步骤和容。进程的树形结构采用广义二叉树的方式进展存储。三、实验原理1进程控制块为了描述和控制进程的运行,系统为每个进程定义了一个进程控制块PCB,它是进程实体的一局部,是操作系统管理进程最重要的数据结构。其主要包含四类信息:(1) 进程标识符它唯一地标识一个进程。通常包括进程号 pid,父进程号 ppid 和用户号 uid
2、。(2) 处理机状态处理器的状态通常由处理机的各种存放器中的容组成。PCB 存放中断阻塞,挂起时的各存放器值,当该进程重新执行时,可以从断点处恢复。主要包括: a) 通用存放器; b) 指令计数器; c) 程序状态字 PSW; d) 用户栈指针。(3) 进程调度信息 a) 进程状态; b) 进程优先级用于描述优先使用 cpu 级别的一个整数,高优先级的进程先得到cpu,通常情况下,优先值越小优先级越高; c) 其它信息等待时间、总执行时间等; d) 事件等待原因。(4) 进程控制信息 a) 程序和数据的地址程序在存和外存中的首址; b) 进程同步和通信机制; c) 资源列表进程除 CPU 以外
3、的所有资源; d) 指针进程队列中指向下一个进程的 PCB 首址。2) 进程创建流程 (1) 申请空白 PCB 为新进程申请获得唯一的数字标识符,并从 PCB 集合中索取一个空白 PCB。如果无空白PCB,可以创建一个新的 PCB。在本实验中,每次动态创建 PCB。 (2) 为新进程分配资源 为新进程分配存空间和栈空间。 (3) 初始化进程控制块 a) 初始化标识信息; b) 初始化处理机状态信息; c) 初始化处理机控制信息。 (4) 将新进程插入就绪队列P1P2P3P4P5P6P7P8P9P10P11P12 3) 进程树 图 1-1 进程树 进程树用于描述进程家族关系,如图 1-1 中可以
4、看出,进程 P1 创建了进程 P2、P3、P4、P5,而 P2 又创建了 P6、P7、P8 。在进程创建过程中,需要对每一个新增加的进程参加到进程树中,有了清晰的父子关系,可以使资源继承或进程删除等操作变得很方便。4) 进程总链它是一个 PCB 链表,每一个新创建的进程必须把其 PCB 放入总链中,该总链可以对破坏的进程树进展修复,也方便 PCB 查找。四、可能用到的数据结构和操作的局部代码1.数据结构/process control block:有些pcb的容是考虑到以后调度功能而设置的struct pcb int pid;/process id int ppid;/parent proce
5、ss id int prio;/priority int state;/state int lasttime;/last execute time int tottime; /totle execute time;/process nodestruct pnode pcb *node; pnode *sub; pnode *brother; pnode *next;/信号量struct semphore char name5; /名称 int count;/计数值 int curpid;/当前进程 id pnode *wlist; /等待链表;2.1 /初始化错误提示信息; /create p
6、rocessint createpc(int *para)/add your code here:/ find ppid of this process/init new pcb/add to process tree/ add to process link/show process detailvoid showdetail() /add your code here /print all pcb info/main函数可参考下面的代码,也可以自己写void main() initerror(); short cflag/*命令标志*/,pflag/*参数标志*/; char cmdstr
7、32; proot = new pnode; /创建根节点进程 proot-node=new pcb;/初始化根节点的pcb proot-node-pid=0; proot-node-ppid=-1; proot-node-prio=0; proot-next=NULL; proot-sub=NULL; proot-brother=NULL; plink=proot; for(;) cflag=0; pflag=0; printf(cmd:); scanf(%s,cmdstr); if(!strcmp(cmdstr,exit) /exit the program break; if(!strc
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 实验 进程 创建 模拟 报告 材料
链接地址:https://www.desk33.com/p-18429.html