ImageVerifierCode 换一换
格式:DOC , 页数:32 ,大小:570KB ,
资源ID:1229659      下载积分:12 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/1229659.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(广工操作系统实验报告.doc)为本站上传会员【精****】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

广工操作系统实验报告.doc

1、 操作系统实验报告 学生学院____ 计算机学院______ 专业班级_ 计科(8)班 学 号 学生姓名____ _______ 指导教师_____ ____ 2013年 12月 29 日 目录 1 实验一 进程调度………………………………………………………………5 2 实验二 作业调度………………………………………………………………9 3 实验三 可变式分区分配………………………………………

2、………………18 4 实验四 简单文件系统…………………………………………………………26 实验一 进程调度 一、实验目的 编写并调试一个模拟的进程调度程序,采用“短进程优先”调度算法对五个进程进行调度。以加深对进程的概念及进程调度算法的理解. 二、实验内容及要求 编写并调试一个模拟的进程调度程序,采用“短进程优先”调度算法对五个进程进行调度。 三、实验设计方案及原理 在多道程序系统中,一个作业被提交后必须经过处理

3、机调度后,方能获得处理机执行。对调度的处理又都可采用不同的调度方式和调度算法。调度算法是指:根据系统的资源分配策略所规定的资源分配算法。 短进程优先调度算法是指对短进程优先调度的算法,它是从后备队列中选择一个或者若干个进程,将处理机分配给它,使它立即执行并一直执行到完成,或发生某事件而被阻塞放弃处理机时再重新调度。 四、重要数据结构或源程序中疑难部分的说明,需附详细注释 #include "stdio.h" #include #include #define

4、getpch(type) (type*)malloc(sizeof(type)) #define NULL0 struct pcb { /* 定义进程控制块PCB */ char name[10]; //进程名 char state; //状态 int super; //优先数 int ntime; //需要运行时间 int rtime; //运行时间 struct pcb* link; }*ready=NULL,*p; typedef struct pcb PCB; int num; sort(

5、) /* 建立对进程进行短进程优先排列函数*/ { PCB *first, *second; int insert=0; if((ready==NULL)||((p->ntime)<(ready->ntime))) /*需要运行时间最小者,插入队首*/ { p->link=ready; ready=p; } else /* 进程比较需要运行时间,插入适当的位置中*/ { first=ready; second=first->link; while(second!=NULL) {

6、if((p->ntime)<(second->ntime)) /*若插入进程比当前进程需要运行时间小,*/ { /*插入到当前进程前面*/ p->link=second; first->link=p; second=NULL; insert=1; } else /* 插入进程需要运行时间最大,则插入到队尾*/ { first=first->link; second=second->link; } } if(insert==0) fir

7、st->link=p; } } void input() /* 建立进程控制块函数*/ { int i; //clrscr(); /*清屏*/ printf("\n 请输入进程数:"); scanf("%d",&num); for(i=0;iname); printf("\n 输入进程需要运行时间:"); sca

8、nf("%d",&p->ntime); printf("\n"); p->rtime=0;p->state='w'; p->link=NULL; sort(); /* 调用sort函数*/ } } void main() /*主函数*/ { int i,len,h=0; char ch; input(); ch=getchar(); printf("\n调度序列为:"); p=ready; for(i=num;i>0;i--) { printf(" %s",p->name);

9、 p=p->link; } printf("\n\n 进程已经完成.\n"); ch=getchar(); } 五、程序运行结果 七、结果分析与实验小结 结果正确。 短进程优先需要把进程按左右运行时间排序,然后让其按顺序执行即可。 实验二 作业调度 一、 实验目的:用高级语言编写和调试一个或多个作业调度的模拟程序,以加深对作业调度算法的理解。 二、 实验内容: 1. 写并调试一个单道处理系统的作业等待模拟程序。 2. 作业等待算法:分别采用先来先服务(FCFS)、响应比高者优先(HRN)的调度算法。 3. 由于在单道批处理

10、系统中,作业一投入运行,它就占有计算机的一切资源直到作业完成为止,因此调度作业时不必考虑它所需要的资源是否得到满足,它所占用的 CPU时限等因素。 4. 每个作业由一个作业控制块JCB表示,JCB可以包含如下信息:作业名、提交时间、所需的运行时间、所需的资源、作业状态、链指针等等。作业的状态可以是等待W(Wait)、运行R(Run)和完成F(Finish)三种状态之一。每个作业的最初状态总是等待W。 5. 对每种调度算法都要求打印每个作业开始运行时刻、完成时刻、周转时间、带权周转时间,以及这组作业的平均周转时间及带权平均周转时间。 5、重要数据结构或源程序中疑难部分的说明,需附详细注释

11、 三、实验设计方案及原理 编写一个程序将输入的进程按其提交时间进行排列,按排列顺序进行调度,计算其开始时间、完成时间、周转时间等数值 四、重要数据结构或源程序中疑难部分的说明,需附详细注释 先来先服务 #include "stdio.h" #include #include #define getpch(type) (type*)malloc(sizeof(type)) #define NULL0 struct pcb { /* 定义进程控制块PCB */ char name[1

12、0]; //进程名 char state; //状态 int super; //优先数 int ntime; //需要运行时间 int rtime; //运行时间 int ctime; //提交时间 int stime; //开始时间 int ftime; //完成时间 int ttime; //周转时间 float dtime; //带权周转时间 struct pcb* link; }*ready=NULL,*p; typedef struct pcb PCB; int num; void sort() /*

13、 建立对进程先来先服务排列函数*/ { PCB *first, *second; int insert=0; if((ready==NULL)||((p->ctime)<(ready->ctime))) /*达到时间最小者,插入队首*/ { p->link=ready; ready=p; } else /* 进程比较到达时间,插入适当的位置中*/ { first=ready; second=first->link; while(second!=NULL) { if((p->cti

14、me)<(second->ctime)) /*若插入进程比当前进程到达时间小,*/ { /*插入到当前进程前面*/ p->link=second; first->link=p; second=NULL; insert=1; } else /* 插入进程到达时间最大,则插入到队尾*/ { first=first->link; second=second->link; } } if(insert==0) first->link=p;

15、 } } void input() /* 建立进程控制块函数*/ { int i; //clrscr(); /*清屏*/ printf("\n 请输入进程数:"); scanf("%d",&num); for(i=0;iname); printf("\n 输入提交时间:"); scanf("%d",&p->ctime)

16、 printf("\n 输入进程需要运行时间:"); scanf("%d",&p->ntime); printf("\n"); p->rtime=0;p->state='w'; p->link=NULL; sort(); /* 调用sort函数*/ } } void main() /*主函数*/ { PCB *first,*second; int i,x,y; float s1=0,s2=0; char ch; input(); ch=getchar(); //输出 printf("进程名\t

17、 开始时间\t 完成时间\t 周转时间\t 带权周转时间\n"); second=ready; first=ready; first->ftime=0; for(i=num;i>0;i--) { if(second->ctime>first->ftime) /*计算完成时间,周转时间等*/ second->stime=second->ctime; else second->stime=first->ftime; second->ftime=(second->ntime)+(second->stim

18、e); second->ttime=(second->ftime)-(second->ctime); x=second->ttime; y=second->ntime; second->dtime=(float)x/(float)y; printf(" %s \t %d \t %d \t %d \t %f \n",second->name,second->stime,second->ftime,second->ttime,second->dtime); s1=s1+second

19、>ttime; s2=s2+second->dtime; if(second->link!=NULL) { first=second; second=second->link; } } s1=s1/num; s2=s2/num; printf("\n平均周转时间=%f\n",s1); printf("平均周转时间=%f\n\n",s2); printf("按任意键结束……"); ch=getchar(); } 响应比 #include #include

20、 #include #define getpch(type) (type*)malloc(sizeof(type)) #define null 0 int n; float T1=0,T2=0; int times=0; struct jcb //作业控制块 { char name[10]; //作业名 int ctime; //作业到达时间 int stime; //作业开始时间 int ntime; //作业需要运行的时间 float super; //作业的响应比 int f

21、time; //作业完成时间 float ttime; //作业周转时间 float dtime; //作业带权周转时间 char state; //作业状态 struct jcb *next; //结构体指针 }*ready=NULL,*p,*q; typedef struct jcb JCB; void inital() //建立作业控制块队列,先将其排成先来先服务的模式队列 { int i; printf("\n输入作业数:"); scanf("%d",&n);

22、 for(i=0;iname); printf("\n输入作业到达时间:"); scanf("%d",&p->ctime); printf("\n输入作业需要运行的时间:"); scanf("%d",&p->ntime); p->state='W'; p->next=NULL;

23、 if(ready==NULL) ready=q=p; else{ q->next=p; q=p; } } } void output(JCB* q) { /*显示所有作业的情况*/ JCB *pr=ready;float f=0.0; printf("所有作业的情况:\n");//列表显示所有作业的情况 printf("作业名\t\t到达时间\t所需运行间\t响应比\t\t作业状态\n"); printf("%s\t

24、\t%d\t\t%d\t\t%f\t%c\n", q->name,q->ctime,q->ntime,q->super,q->state); while(pr) { if(pr->super<=0) printf("%s\t\t%d\t\t%d\t\t%f\t%c\n", pr->name,pr->ctime,pr->ntime,f,pr->state); else printf("%s\t\t%d\t\t%d\t\t%f\t%c\n", pr->name,pr->ctime,pr->ntime,pr->super,pr->state); p

25、r = pr->next; } } void disp(JCB* q) //显示作业运行后的周转时间及带权周转时间等 { //显示高响应比算法调度作业后的运行情况 output(q); printf("\n作业%s正在运行,估计其运行情况:\n",q->name); printf("开始运行时刻\t完成时刻\t周转时间\t带权周转时间\t相应比\n\n"); printf("%d\t\t%d\t\t%f\t%f\t%f\n",q->stime,q->ftime,q->ttime,q

26、>dtime,q->super); getchar(); } void running(JCB *p) //运行作业 { if(p==ready) //先将要运行的作业从队列中分离出来 { ready=p->next; p->next=NULL; } else { q=ready;

27、 while(q->next!=p) q=q->next; q->next=p->next; } p->stime=times; //计算作业运行后的完成时间,周转时间等等 p->state='R'; p->ftime=p->stime+p->ntime; p->ttime=(float)(p->ftime-p->ctime); p->dtime=(float)(p->ttime/p->ntime);

28、 T1+=p->ttime; T2+=p->dtime; disp(p); //调用disp()函数,显示作业运行情况 times+=p->ntime; p->state='F'; printf("\n作业%s已经完成!\n请输入任意键继续......\n",p->name); free(p); //释放运行后的作业 getchar(); } void super()

29、 //计算队列中作业的高响应比 { JCB *padv; padv=ready; do{ if(padv->state=='W'&&(padv->ctime)<=times) { padv->super=(float)(times-padv->ctime+padv->ntime)/padv->ntime; } padv=padv->next; }while(padv!=NULL); } void final() //最后打印作业的平均周转时间,平均带权周转时间 { float s,t;

30、 t=T1/n; s=T2/n; getchar(); printf("\n\n作业已经全部完成!"); printf("\n%d个作业的平均周转时间是:%f",n,t); printf("\n%d个作业的平均带权周转时间是%f:\n\n\n",n,s); } void hrn() //高响应比算法 { JCB *min; int i,iden; system("cls"); inital(); for(i=0;i

31、den=1; super(); do{ if(p->state=='W'&&p->ctime<=times) if(iden) { min=p;iden=0; } else if(p->super>min->super) min=p; p=p->next; }while(p!=NULL); running(min)

32、 //调用running()函数 } final(); //调用running()函数 } void main() //主函数 { hrn(); getchar(); printf("按回车结束\n"); getchar(); // system("cls"); } 五、程序运行结果 七、结果分析与实验小结 实验三 动态分区分配方式的模拟 一、实验目的:了解动态分区分配方式中的数据结构和分配算法,并进一步加深对动态分区存

33、储管理方式及其实现过程的理解 二、实验内容: (1)用C语言分别实现采用首次适应算法和最佳适应算法的动态分区分配过程和回收过程。其中,空闲分区通过空闲分区链(表)来管理;在进行内存分配时,系统优先使用空闲区低端的空间。 (2)假设初始状态下,可用的内存空间为640KB,并有下列的请求序列: •作业1申请130KB •作业2申请60KB •作业3申请100KB •作业2释放60KB •作业4申请200KB •作业3释放100KB •作业1释放130KB •作业5申请140KB •作业6申请60KB •作业7申请50KB •作业8申请60KB 请分别采用首次适应算法和

34、最佳适应算法进行内存的分配和回收,要求每次分配和回收后显示出空闲内存分区链的情况。 三、实验设计方案及原理 首次适应算法:使用该算法进行内存分配时,从空闲分区链首开始查找,直至找到一个能满足其大小要求的空闲分区为止。然后再按照作业的大小,从该分区中划出一块内存分配给请求者,余下的空闲分区仍留在空闲分区链中。 最佳适应算法:该算法总是把既能满足要求,又是最小的空闲分区分配给作业。为了加速查找,该算法要求将所有的空闲区按其大小排序后,以递增顺序形成一个空白链。这样每次找到的第一个满足要求的空闲区,必然是最优的。孤立地看,该算法似乎是最优的,但事实上并不一定。因为每次分配后剩余的空间一定是

35、最小的,在存储器中将留下许多难以利用的小空闲区。同时每次分配后必须重新排序,这也带来了一定的开销。 五、重要数据结构或源程序中疑难部分的说明,需附详细注释 #include "stdio.h" #include #include #define Free 0 //空闲状态 #define Busy 1 //已用状态 #define OK 1 //完成 #define ERROR 0 //出错 #define MAX_length 640 //最大内存空间为KB typedef int Status;

36、 typedef struct freearea//定义一个空闲区说明表结构 { int ID; //分区号 long size; //分区大小 long address; //分区地址 int state; //状态 }ElemType; //---------- 线性表的双向链表存储结构 ------------ typedef struct DuLNode //double linked list { ElemType data; struct DuLNode *prior; //前趋指针 struct DuLNode *nex

37、t; //后继指针 }DuLNode,*DuLinkList; DuLinkList block_first; //头结点 DuLinkList block_last; //尾结点 Status alloc(int);//内存分配 Status free(int); //内存回收 Status First_fit(int,int);//首次适应算法 Status Best_fit(int,int); //最佳适应算法 void show();//查看分配 Status Initblock();//开创空间表 Status Initblock()//开创

38、带头结点的内存空间链表 { block_first=(DuLinkList)malloc(sizeof(DuLNode)); block_last=(DuLinkList)malloc(sizeof(DuLNode)); block_first->prior=NULL; block_first->next=block_last; block_last->prior=block_first; block_last->next=NULL; block_last->data.address=0; block_last->data.size=MAX_length;

39、 block_last->data.ID=0; block_last->data.state=Free; return OK; } //----------------------- 分配主存------------------------- Status alloc(char ch) { int ID=0,request=0; printf("请输入作业(分区号):"); scanf_s("%d",&ID); printf("请输入需要分配的主存大小(单位:KB):"); scanf_s("%d",&request); if(request<

40、0 ||request==0) { printf("分配大小不合适,请重试!\n"); return ERROR; } if(ch==2) //选择最佳适应算法 { if(Best_fit(ID,request)==OK) printf("分配成功!\n"); else printf("内存不足,分配失败!\n"); return OK; } else //默认首次适应算法 { if(First_fit(ID,request)==OK) printf("分配成功!\n"); else printf("内存不足,分配失

41、败!\n"); return OK; } } //------------------ 首次适应算法----------------------- Status First_fit(int ID,int request)//传入作业名及申请量 { //为申请作业开辟新空间且初始化 DuLinkList temp=(DuLinkList)malloc(sizeof(DuLNode)); temp->data.ID=ID; temp->data.size=request; temp->data.state=Busy; DuLNode *p=blo

42、ck_first->next; while(p) { if(p->data.state==Free && p->data.size==request) {//有大小恰好合适的空闲块 p->data.state=Busy; p->data.ID=ID; return OK; break; } if(p->data.state==Free && p->data.size>request) {//有空闲块能满足需求且有剩余" temp->prior=p->prior; temp->next=p;

43、 temp->data.address=p->data.address; p->prior->next=temp; p->prior=temp; p->data.address=temp->data.address+temp->data.size; p->data.size-=request; return OK; break; } p=p->next; } return ERROR; } //-------------------- 最佳适应算法 ------------------------ Status Be

44、st_fit(int ID,int request) { int ch; //记录最小剩余空间 DuLinkList temp=(DuLinkList)malloc(sizeof(DuLNode)); temp->data.ID=ID; temp->data.size=request; temp->data.state=Busy; DuLNode *p=block_first->next; DuLNode *q=NULL; //记录最佳插入位置 while(p) //初始化最小空间和最佳位置 { if(p->data.state==Free &&

45、 (p->data.size>request || p->data.size==request) ) { q=p; ch=p->data.size-request; break; } p=p->next; } while(p) { if(p->data.state==Free && p->data.size==request) {//空闲块大小恰好合适 p->data.ID=ID; p->data.state=Busy; return OK; break; } if(p->da

46、ta.state==Free && p->data.size>request) {//空闲块大于分配需求 if(p->data.size-requestdata.size-request;//更新剩余最小值 q=p;//更新最佳位置指向 } } p=p->next; } if(q==NULL) return ERROR;//没有找到空闲块 else {//找到了最佳位置并实现分配 temp->prior=q->prior; temp->next=q;

47、temp->data.address=q->data.address; q->prior->next=temp; q->prior=temp; q->data.address+=request; q->data.size=ch; return OK; } } //----------------------- 主存回收 -------------------- Status free(int ID) { DuLNode *p=block_first; while(p) { if(p->data.ID==ID) {

48、 p->data.state=Free; p->data.ID=Free; if(p->prior->data.state==Free)//与前面的空闲块相连 { p->prior->data.size+=p->data.size; p->prior->next=p->next; p->next->prior=p->prior; } if(p->next->data.state==Free)//与后面的空闲块相连 { p->data.size+=p->next->data.size; if(p

49、>next->next!=NULL) { p->next->next->prior=p; p->next=p->next->next; } } break; } p=p->next; } return OK; } //--------------- 显示主存分配情况------------------ void show() { printf("+++++++++++++++++++++++++++++++++++++++\n"); printf("+++ 主存分配

50、情况 +++\n"); printf("+++++++++++++++++++++++++++++++++++++++\n"); DuLNode *p=block_first->next; while(p) { printf("分区号:"); if(p->data.ID==Free) printf("Free \n"); else printf("%d \n",p->data.ID); printf("起始地址:%d\n",p->data.address); printf("分区大小:%d KB \n",p->data.size);

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

关于我们      便捷服务       自信AI       AI导航        抽奖活动

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

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

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

关注我们 :微信公众号    抖音    微博    LOFTER 

客服