本学期开设了操作系统课程,主要学习了计算机操作系统方面的知识(进程控制、进程调度、请求分页存储管理、设备管理、文件管理),了解了操作系统的相关应用。以下是课程设计五个设计内容的总结。
一、 进程控制。
1.1目的。
通过简单的结构和控制方法,完成模拟进程结构、进程状态和进程控制,掌握进程控制的实现。
1.2完成的内容。
1、用pcb表示整个进程实体,利用随机数方法或键盘控制方法模拟进程执行中产生的事件操作控制进程管理内容。
2、定义pcb:包括理论pcb中的基本内容,如内部id、外部id、进程状态、队列指针。由于无法实现真正的进程创建功能,在实验中只需建立pcb,用它代表完整的进程。
3、定义进程状态转换方式:进程的状态转换是由进程内部操作或操作系统的控制引起,由于无法实现这些功能,采用随机数方法或键盘控制方法模拟,并实现对应的控制程序。随机方法指产生1-6的随机数,分别代表创建进程(c)、结束进程(e)、进程阻塞(b)、激活进程(w)、调度进程(p)、时间片到(t)等事件;键盘模拟方法指定义6种按键代表以上6种事件。
4、根据事件处理就绪队列、阻塞队列和当前执行进程的状态。每次事件处理后应形象地显示出当前系统中的执行进程是哪一个,就绪队列和阻塞队列分别包含哪些进程。
1.3主要数据结构。
void create()
void interupt()
void block()
void wakeup()
if(running==null)
1.4算法设计及流程图。
建立三个链表分别表示就绪队列、执行队列、阻塞队列;
根据不同的命令对相应的队列进行增删改;
1.5小结。
如何实现的?可以以关键部分流程图、主要数据结构、程序整体框架等内容表示。)
二、 请求分页存储器管理。
2.1目的。
通过在第1部分实验基础上实现进程的分页式内存分配和地址转换过程,完成请求分页式存储分配和地址转换过程,掌握页面置换算法:先进先出(fifo)、最近最久未使用(lru)等算法。
2.2完成的内容。
1、建立一个位示图,用来模拟内存的分配情况,位示图的位数与设定的物理块个数相同。程序启动时可利用一组随机0和1填充位示图,表示内存已被占用情况。
2、创建进程时输入进程大小,并根据程序中设定的物理块大小为进程分配物理块,同时建立页表。
3、输入当前执行进程所要访问的逻辑地址,并将其转换成相应的物理地址。
4、进程退出时,根据其页表内容向位示图反向回填“1”。
5、扩充页表,将其变成支持请求和置换功能的二维页表(增加存在位等)。创建进程时可装入固定的前三页(或键盘输入初始装入页数,不同进程的装入个数可以不同),其余页装入到置换空间内。
6、分别采用fifo和lru置换算法对地址转换过程中遇到的缺页现象进行页面置换,可将多次地址转换过程中所涉及到的页号视为进程的页面访问序列,从而计算置换次数和缺页率。
2.3主要数据结构。
struct page_table_item
int pagenum;
int blocknum;
int exist; /存在位。
int modify; /修改位。
int swap_add;
2.4算法设计及流程图。
void terminate()
int i,j,p,q;
if(running==null)
if(running!=null)
elsefree(running);
if(ready!=null)
void translate()
else//blockno=*(running->pagetable + pageno
void dispagetable()/显示执行进程页表。
int i;
if(running==null)
for(i=0;isize,block_size);i++)
printf(" d %d %d %d %d ",(running->pagetable+i)).pagenum,(*running->pagetable+i)).blocknum,(*running->pagetable+i)).
exist,(*running->pagetable+i)).modify,(*running->pagetable+i)).swap_add);
2.5小结。
三、 设备管理。
3.1目的。
通过在前面的实验基础上,完成设备管理功能的模拟,掌握包括通道和控制器的添加和删除,设备的添加、删除,设备的分配和** 。
3.2完成的内容。
1、设备管理子系统涉及到系统设备表(sdt)、通道控制表(chct)、控制器控制表(coct)和设备控制表(dct)来体现输入输出系统的四级结构和**控制。
2、实现上述设备、控制器以及通道的层次关系,同时能够添加或删除新的设备、控制器或通道。
3、通过键盘命令模拟进程执行过程中提出的设备分配或释放请求,并为此请求分配或释放设备。分配设备成功后可将进程状态调整为阻塞,释放设备后变为就绪状态。
4、分配设备时应如果该设备已被其它进程占用,则设备分配失败,请求进程进入阻塞状态,同时等待该设备的释放。如果设备空闲,进程占用设备的同时还应提出申请控制器请求,直到与设备相关的通道都已申请成功为止。
5、设备、控制器或通道的释放应引起对应节点的等待队列中的第一个阻塞进程被唤醒。如果被唤醒的进程还未完成申请操作,应继续执行上级节点的申请操作。
3.3主要数据结构。
struct node *dcts,*cocts,*chcts;//添加头结点,设备,控制器,通道。
struct node *addnode(char *name,struct node *parent,struct node *head){/在以head为头结点队列中添加名为name的节点。
struct node *tmp=head;//查找最末位节点。
while(tmp->next!=null)
tmp=tmp->next;
tmp->next=(struct node *)malloc(sizeof(struct node));
strcpy(tmp->next->name,name);
tmp->next->next=null;
tmp->next->parent=parent;
tmp->next->process=null;
操作系统课程设计报告
西安郵電大學。院系名称 计算机学院。专业名称 软件工程。班级 1104 学生姓名 赵大伟。学号 8位 04113124 指导教师 舒新峰。设计起止时间 2013.11.10 2013.11.20 1 通过观察 分析实验现象,深入理解进程及进程在调度执行和内存空间等方面的特点,掌握在posix 规范中...
操作系统课程设计报告
课程设计。课程名称操作系统。题目名称多级文件系统 2 学生学院计算机学院 专业班级。学号。学生姓名。指导教师。年月日。目录。一 课程设计 6 二 开发工具及环境 6 三 设计内容 6 四 结构图 8 五 部分 9 六 运行截图 11 七 参考文献 15 八 心得体会 15 本课程设计要求设计一个模拟...
操作系统课程设计报告
实验一进程管理。一 实验目的。1 开发一个函数,建立进程控制块和资源控制块结构,并实现相关数据结构的初始化。2 开发一系列操作,由进程调用这些操作,达到控制进程申请或释放各种资源的目的。通过实验理解进程的概念,进程的组成 pcb结构 进程的并发执行和操作系统进行进程管理的相关原语 主要是进程的创建 ...