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

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

ID:39711984

大小:412.79 KB

页数:18页

时间:2019-07-09

电子科大-计算机-操作系统实验报告-2014级资料_第1页
电子科大-计算机-操作系统实验报告-2014级资料_第2页
电子科大-计算机-操作系统实验报告-2014级资料_第3页
电子科大-计算机-操作系统实验报告-2014级资料_第4页
电子科大-计算机-操作系统实验报告-2014级资料_第5页
资源描述:

《电子科大-计算机-操作系统实验报告-2014级资料》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、电子科技大学实验报告学生姓名:郫县LBJ学号:2014666666666指导教师:温柔可爱的刘杰彦实验地点:主楼A2-413实验时间:2017年4月22日上午一、实验室名称:计算机学院主楼机房二、实验项目名称:进程与资源管理实验分工:郫县LBJ进程管理设计郫县小胖子资源管理设计郫县威斯布鲁克进程调度与时钟中断设计三、实验学时:2四、实验原理:此处的实验原理在指导书上非常丰富,因此不照搬过来,主要写出所要使用到知识点,具体实现过程中的原理分析见报告第八部分“实验步骤”处。(一)总体设计系统总体架构如图1所示,最右边部分为进程与资源管理器,属于操作系统内核的功能。要求能够设计与实现

2、一个简单的进程与资源管理器,具有如下功能:完成进程创建、撤销和进程调度;完成多单元(multi_unit)资源的管理;完成资源的申请和释放;完成错误检测和定时器中断功能。图1系统总体结构(一)Testshell设计应具有的功能:1、从终端或者测试文件读取命令;2、将用户需求转换成调度内核函数(即调度进程和资源管理器);3、在终端或输出文件中显示结果:如当前运行的进程、错误信息等。(二)进程管理设计1、进程状态与操作2、进程控制块结构PCB3、主要函数:创建进程、撤销进程(三)资源管理设计1、主要数据结构RCB2、请求资源3、释放资源(五)进程调度与时钟中断设计关键:使用基于优先

3、级的抢占式调度策略,在同一优先级内使用时间片轮转算法。参考课上ppt:一、实验目的:设计和实现进程与资源管理,并完成Testshell的编写,以建立系统的进程管理、调度、资源管理和分配的知识体系,从而加深对操作系统进程调度和资源管理功能的宏观理解和微观实现技术的掌握。二、实验内容:设计与实现一个简单的进程与资源管理器,要求具有如下功能:完成进程创建、撤销和进程调度;完成多单元(multi_unit)资源的管理;完成资源的申请和释放;完成错误检测和定时器中断功能。通过编写测试脚本(testshell)来完成对进程与资源管理器的测试。一、实验环境(设备、元器件):Windows7、

4、VisualStudio2015二、实验步骤:(一)系统功能需求分析:(二)总体框架设计:1、具体原理和总体工作流程分析:首先,通过testshell从测试文件中读入各种命令。然后,对命令进行分析,将用户的需求转换成调度内核函数,也就是说,通过调度进程和资源管理器,实现创建进程、撤销进程、进程调度、对资源进行管理、申请和释放资源、检测错误和定时器中断等功能,从而模拟一个操作系统对进程进行调度和对资源进行管理的过程。最后,在终端或者输出文件中,把一系列操作后的结果显示出来,包括当前运行的进程、错误信息等。2、相关方法和算法:(1)C语言中的结构struct,用来实现PCB、RCB

5、等(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设计模块。在主函数模块中,需要调用其他三个模块

6、,如创建进程、展示父子子进程等操作,需要调用进程管理设计模块;调度算法的执行、展示各种队列等,需要调用testshell设计模块;在进程管理设计模块中,像销毁PCB等操作,需要执行对RCB的释放,则需调用testshell设计模块;在资源管理设计模块中,提供一些最小的操作,不调用其他模块;在testshell设计模块中,设计到对资源和进程的各种操作,需要调用资源管理设计模块和进程管理设计模块。(一)进程管理设计模块详细设计(本部分我负责实现)我们的计划是在在进程管理设计模块中,实现关于进程的各种最基础的结构和操作,具体包括:实现PCB结构体、PCB链表、PCB子节点链表;实现对

7、PCB链表的初始化、对子节点链表的初始化、新建PCB、对PCB链表中进行删除、插入、移除(不free)、从等待和阻塞队列中获取PCB得知、打印当前PCB父节点、打印当前PCB父节点、打印当前PCB子节点链表、插入子队列的尾部、从子队列尾部删除。1、进程状态与操作(1)进程状态共ready/running/blocked三种状态,通过结构struct实现,代码如下:struct{intrunning;intblocked;intready;}PCB_STATUS;//定义pcb状态的三种情况(

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。