




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、南京林業(yè)大學(xué)南方學(xué)院 計(jì)算機(jī)科學(xué)與技術(shù) n120801107 操作系統(tǒng)期末實(shí)習(xí)院系:南方學(xué)院專業(yè):計(jì)算機(jī)科學(xué)與技術(shù)班級:n1208011姓名:李曉雨學(xué)號(hào):n120801107 實(shí)驗(yàn)1 進(jìn)程管理1. 實(shí)驗(yàn)?zāi)康?#183; 加深對進(jìn)程概念的理解,明確進(jìn)程和程序的區(qū)別。· 進(jìn)一步認(rèn)識(shí)并發(fā)執(zhí)行的實(shí)質(zhì)。· 分析進(jìn)程爭用資源的現(xiàn)象,學(xué)習(xí)解決進(jìn)程互斥的方法。· 了解Linux系統(tǒng)中進(jìn)程通信的基本原理。 2. 實(shí)驗(yàn)預(yù)備內(nèi)容(1)閱讀Linux的sched.h 源碼文件,加深對進(jìn)程管理概念的理解。(2)閱讀Linux的fork.c源碼文件,分析進(jìn)程的創(chuàng)建過程。3. 實(shí)驗(yàn)內(nèi)容 (1)
2、進(jìn)程的創(chuàng)建 (2)編寫一段程序,使用系統(tǒng)調(diào)用fork()創(chuàng)建兩個(gè)子進(jìn)程。當(dāng)此程序運(yùn)行時(shí),在系統(tǒng)中有一個(gè)父進(jìn)程和兩個(gè)子進(jìn)程活動(dòng)。讓沒一個(gè)進(jìn)程在屏幕上顯示一個(gè)字符:父進(jìn)程顯示字符“a”;子進(jìn)程分別顯示字符“b”和字符“c”。試觀察記錄屏幕上的顯示結(jié)果,并分析原因。4. 實(shí)驗(yàn)程序 #include<stdio.h>Main()int p1,p2;while(p1=fork()= -1);if(p1=0)putchar(b)elsewhile(p2=fork()= -1);if(p2=0)putchar(c);else putchar(a); putchar(n);5.實(shí)驗(yàn)結(jié)果程序運(yùn)行后出
3、現(xiàn)bac、bca、abc等多種情況。實(shí)驗(yàn)2 進(jìn)程間通信一、實(shí)驗(yàn)?zāi)康腖inux系統(tǒng)的進(jìn)程通信機(jī)構(gòu)(IPC)允許在任意進(jìn)程間大批量地交換數(shù)據(jù)。本實(shí)驗(yàn)的目的是了解和熟悉Linux支持的消息通信機(jī)制、共享存儲(chǔ)區(qū)機(jī)制及信息機(jī)制。二、實(shí)驗(yàn)預(yù)備內(nèi)容閱讀Linux系統(tǒng)的msg.csem.c等源碼文件,熟悉Linux的三種通信機(jī)制。三、實(shí)驗(yàn)內(nèi)容(1)消息的創(chuàng)建,發(fā)送和接收。1.使用系統(tǒng)調(diào)用msgget( ),msgsnd( ),msgrev( )j及msgctl( )編制一長度1k的消息的發(fā)送和接收程序。2.觀察上面程序,說明控制消息隊(duì)列系統(tǒng)msgctl()在此起什么作用?3. 實(shí)驗(yàn)程序#include<
4、stdio.h>#include<stdlib.h>#include<sys/types.h>#include<sys/msg.h>#include<sys/ipc.h>#define MSGKEY 75struct msgform long mytype; char mtext1030;msg;int msgqid,i;void CLENT()int i; msgqid=msgget(MSGKEY,0777);for(i=10;i>=1;i- -) msg.mytype=i; printf(“(client)sentn”);msgs
5、nd(msgqid,&msg,1024,0); /*發(fā)送消息msg入msgqid消息隊(duì)列*/exit(0);void SERVER()msgqid=msgget(MSGKEY,0777LIPC_CREAT); /*由關(guān)鍵字獲得消息隊(duì)列*/ do msgrcv(msgqid,&msg,1030,0,0); /*從msgqid隊(duì)列接受消息msg*/printf(“(server)receivedn”);while(msg.mytype!=1);msgctl(msgqid,IPC-RMID,0); /*消息隊(duì)列為1時(shí)釋放隊(duì)列*/Exit(0);void main() while(i=
6、fork()=-1);if(!i)SERVER();while(i=fork()=-1;if(!i)CLIENT();wait(0);wait(0);4、實(shí)驗(yàn)結(jié)果:useruser-desktop:$ gcc -0 shiyan2 shiyan2.cuseruser-desktop:$ ./shiyan2(client)sent(client)sent(client)sent(server)received(server)received(server)received(client)sent(client)sent(server)received(client)sent(server)rec
7、eived(client)sent(server)received(client)sent(server)received(client)sent(server)received(client)sent(server)received(server)receiveduseruser-desktop:$實(shí)驗(yàn)3 存儲(chǔ)管理1.實(shí)驗(yàn)?zāi)康模?存儲(chǔ)管理的主要功能之一是合理地分配空間。請求頁式管理式一種常用的虛擬存儲(chǔ)管理技術(shù)。 本實(shí)驗(yàn)的目的是通過請求頁式存儲(chǔ)管理中頁面置換算法模擬設(shè)計(jì),了解虛擬存儲(chǔ)技術(shù)的特點(diǎn),掌握請求頁式存儲(chǔ)管理的頁面置換算法。2.實(shí)驗(yàn)內(nèi)容:(1)通過隨機(jī)數(shù)產(chǎn)生一個(gè)指令序列,共320條指令。
8、指令的地址按下述原則生成:150的指令是順序執(zhí)行的;225的指令是均勻分布在前地址部分;325的指令是均勻分布在后地址部分。3實(shí)驗(yàn)程序#include <stdio.h>#define TRUE 1#define FALSE 0#define INVALID -1#define NULL 0#define total_instruction 320#define total_vp 32#define clear_period 50typedef struct int pn,pfn,counter,time;pl_type;pl_type pltotal_vp;struct pfc_
9、struct *next;typedef struct pfc_struct pfc_type;Pfc_type pfctotal_vp,*freepf_head,*busypf_head,*busypf_tail;int disaffect,atotal_instruction,offsettotal_instruction;int total_pf;void initialize(total_pf)int i;disaffect=0;for(i=0;i<total_vp;i+) pli.pn=I;pli.pfn=INVALID;pli.counter=0;pli.time=-1;fo
10、r(i=1;i<total_pf;i+) pfci-1.next=&pfci;Pfci-1.pfn=i-1;pfctotal_pf-1.next=NULL;pfctotal_pf-1.pfn=total_pf-1;freepf_head=&pfc0;void FIFO(total_pf)int total_pf; int I,j;pfc_type*p,*t;initialize(total_pf);busypf_head=busypf_tail=NULL;for(i=0;total_instruction;i+)if(plpagei.pfn=INVALID)disaffe
11、ct+=1;If(freepf_head=NULL)p=busypf_head->next;plbusypf_head->pn.pfn=INVALID;freepf_head=busypf_head;freepf_head->next=NULL;busypf_head=p;p=freepf_head->next;freepf_head->next=NULL;freepf_head->pn=pagei;plpagei.pfn=freepf_head->pfn;if(busypf_tail=NULL) busypf_head=busypf_tail=fre
12、epf_head; else busypf_tail->next=freepf_head; busypf_tail=freepf_head; freepf_head=p; printf(“FIFO:%6.4f”,1-(float)diseffect/320);void LRU(total_pf)int total_pf; int min,minj,i,j,present_time; initialize(total_pf);present_time=0;for(i=0;i<total_instruction;i+) if(plpagei.pfn=INVALID) diseffect
13、+; if(freepf_head=NULL) min=32767; for(j=0;j<total_vp;j+) if(min>plj.time&&plj.pfn!=INVALID)min=plj.time;min j=j;freepf_head=&pfcplmin j.pfn;plminj.pfn=INVALID;plminj.time=-1;freepf_head->next=NULL; plpagei.pfn=freepf_head->pfn; plpagei.time=present_time; freepf_head=freepf_h
14、ead->next;else plpagei.time=present_time; present_time+;printf(“LRU:%6.4f”,1-(float)diseffect/320);void NUR(total_pf)int total_pf;int i,j,dp,cont_flag,old_dp;pfc_type*t;initiallze(total_pf);dp=0;for(i=o;i<total_instruction;i+)if(plpagei.pnf=INVALID)disaffect+;if(freep_head=NULL)cont_flag=TURE;
15、old_dp=dp;while(cont_flag)if(pldp.counter=0&&pldp.pfn!=INVALID)cont_flag=FALSE;elsedp+;if(dp=total_vp)dp=0;for(j=0;j<total_vp;j+)plj.counter=0;freepf_head=&pfcpldp.pnf;pldp.pnf=INVALD;freep_head->next=NULL);plpagei.pfn=freepf_head->pfn;freepf_head=freepf_head->next;elseplpage
16、i.counter=1;if(i%clear_period=0)for(j=0;j<total_vp;j+)plj.counter=0;printf(“NUR:%6.4f”,1-(float)disaffect/320);void OPT(total_pf)Inttotal_pf;intI,j,max,maxpage,d,disttotal_vp;pfc_type*t;initialize(total_pf);for(i=0;i<total_instruction;i+)if(plpagei.pnf=INVALID)disaffect+;if(freepf_head=NULL)fo
17、r(j=0;j<total_vp;j+)if(plj.pfn=INVALID)distj=32767;else distj=0;d=1;for(j=i+1;j<total_instruction;j+)if(plpagej.pfn!=INVALID)distpagej=d;d+;max=-1;for(j=0;j<total_vp;j+)if(max<distj) max=distj;Maxpage=j;freepf_head=&pfcplmaxpage.pfn;freepf_head->next=NULL;plmaxpage.pfn=INVALID;plp
18、agei.pfn=freepf_head->pfn;freepf_head=freepf_head->next;printf(“OPT:%6.4f”,1-(float)disaffect/320);Void LFU(total_pf)int total_pf; int i,j,min,minpage;pfc_type*t;initialize(total_pf);for(i=0;i<total_instruction;i+) if(plpagei.pfn=INVALID)disaffect+;if(freepf_head=NULL)min=32767;for(j=0;j<
19、;total_vp;j+)if(min>plj.counter&&plj.pfn!=INVALID)min=plj.counter;minpage=j;Plj.counter=0;freep_head=&pfcplminpage.pfn;plminpage.pfn=INVALID;freepf_head->next=NULL;plpagei.pfn=freepf_head->pfn;freepf_head=freepf_head->next;elsePlpagei.counter+;Printf(“LFU:%6.4f”,1-(float)dise
20、ffect/320);main()int s,i,j; srand(getpid()*10); S=319*rand()/32767+1; for(i=0;i<total_instruction;i+=4) ai=s; ai+1=ai+1; ai+2=ai*rand()/32767; ai+3=ai+2+1; s=rand()*(318-ai+2)/32767+ai+2+2;for(i=0;i<total_instruction;i+)pagei=ai%32; Offseti=ai%10;for(i=4;i<=32;i+)printf(“%2d page frames”,i)
21、; FIFO(i); LRU(i); OPT(i); LFU(i); NUR(i); printf(“n”);4.實(shí)驗(yàn)結(jié)果useruser-desktop:$./3 4page framesFIFO:0.4813LRU:0.48130PT:0.5437LFU:0.4844NUR:0.5062 5page framesFIFO:0.5250LRU:0.52810PT:0.5656LFU:0.5031NUR:0.5375 6page framesFIFO:0.5406LRU:0.54690PT:0.5781LFU:0.5219NUR:0.5312 7page framesFIFO:0.5594LR
22、U:0.55630PT:0.5938LFU:0.5469NUR:0.5312 8page framesFIFO:0.5687LRU:0.56560PT:0.6219LFU:0.5625NUR:0.5687 9page framesFIFO:0.6000LRU:0.57810PT:0.6406LFU:0.5781NUR:0.609410pageframesFIFO:0.6062LRU:0.60620PT:0.6562LFU:0.6000NUR:0.603111pageframesFIFO:0.6188LRU:0.61250PT:0.6719LFU:0.6156NUR:0.618812page f
23、ramesFIFO:0.6344LRU:0.62500PT:0.6906LFU:0.6312NUR:0.631213page framesFIFO:0.6469LRU:0.63750PT:0.7031LFU:0.6406NUR:0.631214page framesFIFO:0.6813LRU:0.65310PT:0.7188LFU:0.6531NUR:0.675015page framesFIFO:0.6906LRU:0.66870PT:0.7281LFU:0.6719NUR:0.700016page framesFIFO:0.7031LRU:0.68750PT:0.7500LFU:0.6781NUR:0.696917page framesFIFO:0.7250LRU:0.71560PT:0.7625LFU:0.7219NUR:0.725018page framesFIFO:0.7344LRU:0.73440PT:0.7812LFU:0.7344NUR:0.743819page framesFIFO:0.7469LRU:0.76250PT:0.7969LFU:0.7469NUR:0.753120page framesFIFO:0.7781LRU:0.77500PT:0.8031LFU:0.7656N
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 藥庫設(shè)備維護(hù)管理制度
- 藥店獎(jiǎng)罰規(guī)章管理制度
- 藥店設(shè)備投放管理制度
- 營林防火安全管理制度
- 設(shè)備公司營銷管理制度
- 設(shè)備安全細(xì)節(jié)管理制度
- 設(shè)備現(xiàn)場施工管理制度
- 設(shè)施權(quán)屬清冊管理制度
- 設(shè)計(jì)單位員工管理制度
- 詐騙公司經(jīng)營管理制度
- 地鐵線反恐安全培訓(xùn)內(nèi)容
- 基于單片機(jī)的多路數(shù)據(jù)采集系統(tǒng)設(shè)計(jì)(附源程序及原理圖)
- 《跨部門溝通與協(xié)調(diào)》課件
- 2023年哈密市伊吾縣社區(qū)工作者招聘考試真題
- 簡歷篩選技巧培訓(xùn)
- 全國工會(huì)財(cái)務(wù)知識(shí)競賽題庫及答案
- 監(jiān)理日志模板
- 醉駕(酒駕)悔過書
- 2023年湖南省常德市中考地理試卷【附答案】
- 單位干部積分制管理考核制度(五篇)
- 醫(yī)學(xué)公共基礎(chǔ)知識(shí)試題
評論
0/150
提交評論