操作系統(tǒng)試驗報告_第1頁
操作系統(tǒng)試驗報告_第2頁
操作系統(tǒng)試驗報告_第3頁
操作系統(tǒng)試驗報告_第4頁
操作系統(tǒng)試驗報告_第5頁
已閱讀5頁,還剩7頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

1、西安郵電大學(xué)(計算機學(xué)院)課內(nèi)實驗報告實驗名稱:進程管理專業(yè)名稱:計算機科學(xué)與技術(shù)班 級:學(xué)生姓名:學(xué)號(8位指導(dǎo)教師:實驗日期: 年杯月杯日一. 實驗?zāi)康募皩嶒灜h(huán)境目的:(1)加深對進程概念的理解,明確進程和程序的區(qū)別。(2)進一步認(rèn)識并發(fā)執(zhí)行的實質(zhì)。(3)分析進程競爭資源現(xiàn)象,學(xué)習(xí)解決進程互斥的方法。(4)了解Linux系統(tǒng)中進程通信的基本原理。環(huán)境:Linux操作系統(tǒng)壞境:二. 實驗內(nèi)容(1)閱讀Linux的sched. h源文件,加深對進程管理概念的理解。(2)閱讀Linux的fork, c源文件,分析進程的創(chuàng)建過程。三. 方案設(shè)計(1)進程的創(chuàng)建編寫一段源程序,使系統(tǒng)調(diào)用fork()

2、創(chuàng)建兩個子進程,當(dāng)此程序運行時,在系統(tǒng)中有一 個父進程和兩個子進程活動。讓每一個進程在屏幕上顯示一個字符:父進程顯示字符“a” ; 子進程分別顯示字符“b”和字符“c”。試觀察紀(jì)錄屏幕上的顯示結(jié)果,并分析原因。(2)進程的控制修改已編寫的程序,將每個進程輸出一個字符改為每個進程輸出一句話,在觀察程序執(zhí) 行時屏幕出現(xiàn)的現(xiàn)彖,并分析原因。如果在程序中使用調(diào)用lockfO來給每一個子進程加鎖,可以實現(xiàn)進程之間的互斥,觀察 并分析出現(xiàn)的現(xiàn)彖。(3)編寫一段程序,使其現(xiàn)實進程的軟中斷通信。要求:使用系統(tǒng)調(diào)用fork()創(chuàng)建兩個子進程,再用系統(tǒng)調(diào)用signal 0讓父進程捕捉鍵盤 上來的中斷信號(即按DE

3、L鍵):當(dāng)捕捉到中斷信號后,父進程用系統(tǒng)調(diào)用Kill ()向兩個子進 程發(fā)出信號,子進程捕捉到信號后分別輸出下列信息后終止:Child Processll is Killed by Parent!Child Processl2 is Killed by Parent!父進程等待兩個子進程終止后,輸出如下的信息后終止Parent Process is Killed!程序流程圖如下:在上面的程序中増加語句signal (SIGNAL, SIGTGN)和signal (SIGQUIT, SIGTGN), 觀察執(zhí)行結(jié)果,并分析原因。(4) 進程的管道通信編制一段程序,實現(xiàn)進程的管理通信。使用系統(tǒng)調(diào)用p

4、ipe。建立一條管道線;兩個子進程P1和P2分別向管道中寫一句話:Child 1 is sending a message!Child 2 is sending a message!而父進程則從管道中讀出來自于兩個子進程的信息,顯示在屏幕上。要求父進程先接收子進程P1發(fā)來的消息,然后再接收子進程P2發(fā)來的消息。四測試數(shù)據(jù)及運行結(jié)果1 創(chuàng)建進程,顯示結(jié)果bee這是因為程序執(zhí)行時,先執(zhí)行fork()創(chuàng)建進程所需 的時間多于輸出一個字符的時間,因此在主進程創(chuàng)建進程2的同時,進程1就輸 出了 “b” ,而進程2和主程序的輸出次序是有隨機性的,Q00 (luhuljuan(g>ubuntu:T-t

5、 uhu V juanQubunu s -*$ guu -fork . cTuhu 1. JuanubunCu : $ qcc Tork u -o d Tluhui. JuanQubunu:$. /dbc aT-t uhu V juanQubunu s -*$ ©OF liuhuiluan(«pubur>tu:45678901234Z77777888885678901234568888899999994:444:44442 進程的控制liuhuijuan(ubuntu: daughter465daugh tzer-466daugh tzer-467daughter46

6、8daughter469daughter470daughter471daughter472daugh tzer-473daugh tzer-474daughter475daughter476daughter477daughter478daughter479daugh tzer-480daugh tzer-481daughter482daughter483daughter484daughter485daughter486daugh tzer-487daugh七&廠488daugntier daughter dmughter daughter daughter daughtzer daug

7、hter doughtue daughter daughter daughtzer daughter doughtue daughter daughter dmught:e daughter doughtuf daughter daughter dmught:e daughter doughtuf3軟中斷通信 A.O c c lluhuijuanbubuntu: lluhut juanubun*tu : -$ gcc 5c - o a1tuhutjuanubuntu:/aCchLLd process2 ts killed by parent! parent process ts killed!

8、liuhutjuanubuntu:-SB因為沒有了中斷與退出信號,程序一直是阻塞狀態(tài)而無法退出。OOG Uuhuijuanubuntu: lluhutjuanubuntu:-$ gcc 6.c o b liuhutjuanubuntu:-$ /bparent process ts killed關(guān)鍵代碼:main()嚴(yán)創(chuàng)建子進程pl Wuitpl5p2; if(pl=forkO)if(p2=forkO)八創(chuàng)建子進程p2*/wait_mark=l;signal(SIGINT,stop);/*接收到2 信號,轉(zhuǎn) stop*/waitingO;八向pl發(fā)軟中斷信號16*/kill(p2J7);wait

9、(O);/響p2發(fā)軟中斷信號17*/ 廣同步拿/wait(O);printf(Hparent process is killed!nH); exit(O);wait_mark=l;signal(SIGINT, stop);waitingO;lockf(l、0,0);printf("child process2 is killed by parent!nn); lockf( 1,0,0);exit(O);wait_mark=l;signal(SIGINT,stop );waitingO;lockf( 1,0.0);printf(ncliild process 1 is killed b

10、y parentlockf( 1,0.0);exit(O);4進程的管道通信凸® Uuhuijuan(g)ubuntu: lluhutjuanubuntu:-$ gcc 7c -o f Ivuhuijuangubuntu:-$ ./fchild 1 process is sending message! child 2 process xs sending message! Ituhutjuanubuntu:-$ |五總結(jié)1. 在軟中斷通信中,調(diào)用函數(shù)signal ()都放在一段程序的前面位置,而不是在 其接受信號處,這是因為signal ()的執(zhí)行只是為指定信號量16和17的作用,

11、 以及分配相應(yīng)的與stop ()過程的指針。從而signal ()函數(shù)必須在程序前面部 分執(zhí)行。2. 通過這次實驗,加深了對進程管理的認(rèn)識。這次實驗更需要耐心觀察,一步一 步執(zhí)行調(diào)試,不能操之過急。做實驗是對課本知識的鞏固,更是對自己動手能力 的鍛煉。六.附錄:源代碼(電子版)1. 創(chuàng)建進程:#include<stdio.h>mam()intpl,p2;if(pl=fork() putchar(*b*);else if(p2=fork() piitchar('c'); else piitchar('a');嚴(yán)子進程創(chuàng)建成功*/嚴(yán)子進程創(chuàng)建成功*7嚴(yán)父

12、進程執(zhí)行拿/2. 進程的控制程序1.#include<stdio.h>main()intpl,p2,i;if(pl=forkO)for(i=0;i<500;i+)printf(nchild %dnn,i);elseif(p2=fork()fbr(i=0;i<500;i+) printf(uson %dn",i);elsefbr(i=0;i<500;i+)priiitf(Hdaugliter %dn”,i);程序2#include<stdio.h>mam()intpl,p2,i;if(pl=forkO)lockf( 1,1,0);for(i=0

13、;i<500;i+)pnntf(Hchild %dWi);lockf( 1,1,0);elseif(p2=forkQ)lockf( 1,1,0);for(i=0;i<500;i-H-) printf("son %dn",i);lockf( 1,1,0);elselockf( 1,1,0);fbr(i=0 ;i<500;i+) printf(H daughter %dnH,i);lockf(l,0,0);3. 軟中斷通信程序1#include<stdio.h>#include<signal.h>#include<imistd.h

14、>void waitingQ.stopO;int wait_mark;main()uitpl.p2;if(pl=forkO)嚴(yán)創(chuàng)建子進程pl*/if(p2=forkO)/* 創(chuàng)建子進程 p2*/wait_mark=l;signal(SIGINT.stop);/*接收到 信號,轉(zhuǎn) stop*/waitingQ;kill(pl,16);/*向pl發(fā)軟中斷信號16*/kill(p2,17);/響P2發(fā)軟中斷信號17*/wait(O);嚴(yán)同步 */wait(O);printf(Hparent process is killed!iT);exit(O);elsewait_iiiark=l;sign

15、al(SIGINT, stop);waitingQ;lockf(l,0,0);priiitf(nchild process2 is killed by parent!nH);lockf(l,0,0);exit(O);elsewait_mark=l; signal(SIGINT,stop); waitingO; lockf( 1,0,0);printff'child process 1 is killed by pni:ent!n“); lockf( 1,0,0);exit(0);void waitingQwhile (wait_mark!=0);void stopQ wait_mark

16、=0;<程序2>#include<stdio.h>#include<signal.h>#include<imistd.h>int pidl,pid2;mt EndFlag=0;mtpfl=0;mt pf2=0;void IntDelete()kill(pidl,16);kiU(pid2,17);EndFlag=l;void IntlQprintff'child process 1 is killed !by parentnH); exit(0); void Int2Q printff'child process 2 is kill

17、ed !by parentnH); exit(O);main()int exitpid;signal(SIGINT,SIGJGN); signal(SIGQUIT,SIGJGN);if(pidl=fork()signal(SIGUSRl.Intl); signal(SIGINT,SIGJGN);pause。;exit(O);elseif(pid2=fork()signal(SIGUSRlJntl); signal(SIGINT,SIGJGN); pauseQ; exit(O);elsesignal(SIGINTJntDelete); waitpid(-l,&exitpidqO); pr

18、iiitf(nparent process is killed'd'); exit(O);4. 進程的管道通信程序include <unistd.h>include <signal.h>include <stdio.h>int pidl.pid2;mam() int fd2;char outpipe 100,inpipe 100;pipe(fd);八創(chuàng)建一個管道冰/while (pidl=fork(if(pidl=0) lockf(fdlJ,0);sprintfoutpipechild 1 process is sending message !H);/*把串放入數(shù)組outpipe中*/te(fdl.outpipe,50);嚴(yán)向管道寫長為50字節(jié)的串沐/sleep(5);/*自我阻塞5秒*/lockf(fdlA0);exit(0);elsewhile(pid2=

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論