![2024年Linux進(jìn)程管理實(shí)驗(yàn)報(bào)告_第1頁(yè)](http://file4.renrendoc.com/view14/M02/00/10/wKhkGWbVCQCAVeuWAAE1h7kE52M535.jpg)
![2024年Linux進(jìn)程管理實(shí)驗(yàn)報(bào)告_第2頁(yè)](http://file4.renrendoc.com/view14/M02/00/10/wKhkGWbVCQCAVeuWAAE1h7kE52M5352.jpg)
![2024年Linux進(jìn)程管理實(shí)驗(yàn)報(bào)告_第3頁(yè)](http://file4.renrendoc.com/view14/M02/00/10/wKhkGWbVCQCAVeuWAAE1h7kE52M5353.jpg)
![2024年Linux進(jìn)程管理實(shí)驗(yàn)報(bào)告_第4頁(yè)](http://file4.renrendoc.com/view14/M02/00/10/wKhkGWbVCQCAVeuWAAE1h7kE52M5354.jpg)
![2024年Linux進(jìn)程管理實(shí)驗(yàn)報(bào)告_第5頁(yè)](http://file4.renrendoc.com/view14/M02/00/10/wKhkGWbVCQCAVeuWAAE1h7kE52M5355.jpg)
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
《Linux操作系統(tǒng)設(shè)計(jì)實(shí)踐》試驗(yàn)一:進(jìn)程管理試驗(yàn)?zāi)康模海?)加深對(duì)進(jìn)程概念的理解,明確進(jìn)程和程序的區(qū)別。(2)深入認(rèn)識(shí)并發(fā)執(zhí)行的實(shí)質(zhì)。(3)學(xué)習(xí)通過(guò)進(jìn)程執(zhí)行新的目的程序的措施。(4)理解Linux系統(tǒng)中進(jìn)程信號(hào)處理的基本原理。試驗(yàn)環(huán)境:RedHatLinux試驗(yàn)內(nèi)容:(1)進(jìn)程的創(chuàng)立編寫(xiě)一段程序,使用系統(tǒng)調(diào)用fork()創(chuàng)立兩個(gè)子進(jìn)程,當(dāng)此進(jìn)程運(yùn)行時(shí),在系統(tǒng)中有一種父進(jìn)程和兩個(gè)子進(jìn)程活動(dòng),讓每一種進(jìn)程在屏幕上顯示一種字符,父進(jìn)程顯示字符“a”;子進(jìn)程分別顯示字符“b”和字符“c”,試觀測(cè)記錄屏幕上的顯示成果,并分析原因。程序代碼:#include<stdio.h>intmain(){intp1,p2;while((p1=fork())==-1);if(p1==0)putchar('b');else{while((p2=fork())==-1);if(p2==0)putchar('c');elseputchar('a');}return0;}運(yùn)行成果:bca分析:第一種while裏調(diào)用fork()函數(shù)一次,返回兩次。子進(jìn)程P1得到的返回值是0,父進(jìn)程得到的返回值是新子進(jìn)程的進(jìn)程ID(正整數(shù));接下來(lái)父進(jìn)程和子進(jìn)程P1兩個(gè)分支運(yùn)行,判斷P1==0,子進(jìn)程P1符合條件,輸出“b”;接下來(lái)else裏面的while裏再調(diào)用fork()函數(shù)一次,子進(jìn)程P2得到的返回值是0,父進(jìn)程得到的返回值是新子進(jìn)程的進(jìn)程ID(正整數(shù));接下來(lái)判斷P2==0,子進(jìn)程P2符合條件,輸出“c”,接下來(lái)父進(jìn)程輸出“a”,程序結(jié)束。(2)進(jìn)程的控制①修改已編寫(xiě)的程序,將每個(gè)進(jìn)程輸出一種字符改為每個(gè)進(jìn)程輸出一句話,在觀測(cè)程序執(zhí)行時(shí)屏幕上出現(xiàn)的現(xiàn)象,并分析原因。程序代碼:#include<stdio.h>intmain(){intp1,p2;while((p1=fork())==-1);if(p1==0)printf("Child1isrunning!\n");else{while((p2=fork())==-1);if(p2==0)printf("Child2isrunning!\n");elseprintf("Fatherisrunning!\n");}return0;}運(yùn)行成果:Child1isrunning!Child2isrunning!Fatherisrunning!分析:本試驗(yàn)和上一種試驗(yàn)同樣,只是將每個(gè)進(jìn)程輸出一種字符改為每個(gè)進(jìn)程輸出一句話。第一種while裏調(diào)用fork()函數(shù)一次,返回兩次。子進(jìn)程P1得到的返回值是0,父進(jìn)程得到的返回值是新子進(jìn)程的進(jìn)程ID(正整數(shù));接下來(lái)父進(jìn)程和子進(jìn)程P1兩個(gè)分支運(yùn)行,判斷P1==0,子進(jìn)程P1符合條件,輸出“Child1isrunning!”;接下來(lái)else裏面的while裏再調(diào)用fork()函數(shù)一次,子進(jìn)程P2得到的返回值是0,父進(jìn)程得到的返回值是新子進(jìn)程的進(jìn)程ID(正整數(shù));接下來(lái)判斷P2==0,子進(jìn)程P2符合條件,輸出“Child2isrunning!”,接下來(lái)父進(jìn)程輸出“Fatherisrunning!”,程序結(jié)束。②創(chuàng)立進(jìn)程,使用exec函數(shù)族使子進(jìn)程執(zhí)行新的目的程序,觀測(cè)并分析出現(xiàn)的現(xiàn)象。程序代碼:#include<stdio.h>#include<unistd.h>intmain(){printf("===systemcallexecltesting===\n");execlp("date","date",0);printf("execerror!\n");return0;}運(yùn)行成果:===systemcallexecltesting===五11月422:23:51CST分析:創(chuàng)立了進(jìn)程,使用exec函數(shù)族使子進(jìn)程執(zhí)行新的目的程序,輸出成果為目的程序的輸出。(3)進(jìn)程信號(hào)處理編寫(xiě)程序使用系統(tǒng)調(diào)用fork()創(chuàng)立兩個(gè)子進(jìn)程,再用系統(tǒng)調(diào)用singal()讓父進(jìn)程捕捉鍵盤(pán)上來(lái)的中斷信號(hào)(即按Ctrl+c鍵);當(dāng)捕捉到中斷信號(hào)後,父進(jìn)程用系統(tǒng)調(diào)用Kill()向兩個(gè)子進(jìn)程發(fā)出信號(hào),子進(jìn)程捕捉到信號(hào)後分別輸出下列信息後終止:ChildProcess11isKilledbyParent!ChildProcess12isKilledbyParent!父進(jìn)程等待兩個(gè)子進(jìn)程終止後,輸出如下的信息後終止:ParentProcessisKilled!觀測(cè)并分析出現(xiàn)的現(xiàn)象。程序代碼:#include<stdio.h>#include<signal.h>intwait_mark;voidwaiting(){while(wait_mark==1);}voidstop(){wait_mark=0;}intmain(){intp1,p2;while((p1=fork())==-1);if(p1==0){wait_mark=1;signal(SIGINT,SIG_IGN);signal(16,stop);waiting();printf("ChildProcess11isKilledbyParent!\n");exit(0);}else{while((p2=fork())==-1);if(p2==0){wait_mark=1;signal(SIGINT,SIG_IGN);signal(17,stop);waiting();printf("ChildProcess12isKilledbyParent!\n");exit(0);}else{wait_mark=1;signal(SIGINT,stop);waiting();kill(p1,16);kill(p2,17);wait(0);wait(0);printf("ParentProcessisKilled!\n");exit(0);}}}運(yùn)行成果:ChildProcess12isKilledbyParent!ChildProcess11isKilledbyParent!ParentProcessisKilled!分析:程序開(kāi)始調(diào)用fork()函數(shù)創(chuàng)立兩個(gè)子進(jìn)程,初始時(shí)兩個(gè)子進(jìn)程處在等待狀態(tài),再調(diào)用singal()函數(shù)讓父進(jìn)程捕捉鍵盤(pán)上來(lái)的中斷信號(hào)(即按Ctrl+c鍵);當(dāng)父進(jìn)程捕捉到從鍵盤(pán)上傳來(lái)的中斷信號(hào)後,父進(jìn)程調(diào)用Kill()函數(shù)向兩個(gè)子進(jìn)程發(fā)出信號(hào),該信號(hào)的作用是讓子進(jìn)程從等待狀態(tài)轉(zhuǎn)為執(zhí)行狀態(tài),子進(jìn)程捕捉到該信號(hào)後分別執(zhí)行各自的程序,輸出下列信息後終止(子進(jìn)程的輸
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年自來(lái)水廠自動(dòng)化系統(tǒng)項(xiàng)目可行性研究報(bào)告
- 2025年度新能源汽車(chē)電池回收利用合同規(guī)范
- 2025年度國(guó)際教育資源引進(jìn)限制性條款合同
- 2025年度數(shù)據(jù)中心掛靠建設(shè)合同書(shū)
- 2025年度健身俱樂(lè)部智能化管理系統(tǒng)開(kāi)發(fā)合同
- 2025年度滑雪教練員職業(yè)認(rèn)證與培訓(xùn)服務(wù)承包合同
- 2025年度地暖裝修與售后服務(wù)一體化合同范本
- 2025年度影視作品制作與發(fā)行合同范本
- 2025年度焊接設(shè)備出口貿(mào)易合同范本
- 2025年度公路工程項(xiàng)目工程居間代理合同范本
- 2024年中考語(yǔ)文試題分類(lèi)匯編:散文、小說(shuō)閱讀(第03期)含答案及解析
- 《宮頸癌篩查》課件
- 2024年聯(lián)勤保障部隊(duì)第九四〇醫(yī)院社會(huì)招聘考試真題
- 第二章《有理數(shù)的運(yùn)算》單元備課教學(xué)實(shí)錄2024-2025學(xué)年人教版數(shù)學(xué)七年級(jí)上冊(cè)
- DB31-T 596-2021 城市軌道交通合理通風(fēng)技術(shù)管理要求
- 華為智慧園區(qū)解決方案介紹
- 2022年江西省公務(wù)員錄用考試《申論》真題(縣鄉(xiāng)卷)及答案解析
- 2024年國(guó)家公務(wù)員考試《行測(cè)》真題(地市級(jí))及答案解析
- 【招投標(biāo)管理探究的國(guó)內(nèi)外文獻(xiàn)綜述2600字】
- 人教版八年級(jí)英語(yǔ)上冊(cè)期末專(zhuān)項(xiàng)復(fù)習(xí)-完形填空和閱讀理解(含答案)
- 一例蛇串瘡患者個(gè)案護(hù)理課件
評(píng)論
0/150
提交評(píng)論