實(shí)驗(yàn)三-進(jìn)程的創(chuàng)建_第1頁
實(shí)驗(yàn)三-進(jìn)程的創(chuàng)建_第2頁
實(shí)驗(yàn)三-進(jìn)程的創(chuàng)建_第3頁
實(shí)驗(yàn)三-進(jìn)程的創(chuàng)建_第4頁
實(shí)驗(yàn)三-進(jìn)程的創(chuàng)建_第5頁
已閱讀5頁,還剩15頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、上海應(yīng)用技術(shù)學(xué)院程序設(shè)計(jì)語言實(shí)驗(yàn)報(bào)告實(shí)驗(yàn)名稱進(jìn)程的創(chuàng)建實(shí)驗(yàn)序號實(shí)驗(yàn)三實(shí)驗(yàn)日期姓 名學(xué) 號指導(dǎo)教師專 業(yè)計(jì)算機(jī)科學(xué)與技術(shù)班 級 成 績1、 實(shí)驗(yàn)?zāi)康募耙?練習(xí)使用EOS API函數(shù)CreateProcess創(chuàng)建一個進(jìn)程,掌握創(chuàng)建進(jìn)程的方法,理解進(jìn)程和程序的區(qū)別。 調(diào)試跟蹤C(jī)reateProcess函數(shù)的執(zhí)行過程,了解進(jìn)程的創(chuàng)建過程,理解進(jìn)程是資源分配的單位。2、 實(shí)驗(yàn)環(huán)境 Windows XP;Tevation OS Lab。3、 實(shí)驗(yàn)內(nèi)容 1 準(zhǔn)備實(shí)驗(yàn)按照下面的步驟準(zhǔn)備本次實(shí)驗(yàn):1. 啟動OS Lab。2. 新建一個EOS Kernel項(xiàng)目,如圖1。圖13. 分別使用Debug配置和Rele

2、ase配置生成此項(xiàng)目,從而在該項(xiàng)目文件夾中生成完全版本的EOS SDK文件夾,如圖2、圖3。圖2圖34. 新建一個EOS應(yīng)用程序項(xiàng)目,如圖4。圖45. 使用在第3步生成的SDK文件夾覆蓋EOS應(yīng)用程序項(xiàng)目文件夾中的SDK文件夾,使用Debug配置和Release配置生成此項(xiàng)目如圖5、6;使用在第3步生成的SDK文件夾覆蓋EOS應(yīng)用程序項(xiàng)目文件夾中的SDK文件夾,如圖7。圖5圖6圖72 練習(xí)使用控制臺命令創(chuàng)建EOS應(yīng)用程序的進(jìn)程練習(xí)使用控制臺命令創(chuàng)建EOS應(yīng)用程序進(jìn)程的具體步驟如下:1. 在EOS應(yīng)用程序項(xiàng)目的“項(xiàng)目管理器”窗口中雙擊Floppy.img文件如圖8,使用FloppyImageEd

3、itor工具打開此軟盤鏡像文件。圖82. 在OS Lab的“幫助”菜單中選擇“示例”,打開示例文件夾如圖9。圖93. 將示例文件夾中的Hello.exe文件(一個EOS應(yīng)用程序的可執(zhí)行文件,源代碼可以參見該實(shí)驗(yàn)文件夾中的Hello.c源文件)拖動到FloppyImageEditor工具窗口的文件列表中釋放如圖10,Hello.exe文件即被添加到軟盤鏡像文件中。圖104. 在FloppyImageEditor中選擇“文件”菜單中的“保存”如圖11后關(guān)閉FloppyImageEditor。圖115. 按F7生成EOS應(yīng)用項(xiàng)目。6. 按F5啟動調(diào)試。OS Lab會彈出一個調(diào)試異常對話框,并中斷應(yīng)用

4、程序的執(zhí)行。7. 在調(diào)試異常對話框中選擇“否”,忽略異常繼續(xù)執(zhí)行應(yīng)用程序。8. 激活虛擬機(jī)窗口,待該應(yīng)用程序執(zhí)行完畢后,在EOS的控制臺中輸入命令“A:Hello.exe”后回車結(jié)果如圖12。圖129. Hello.exe應(yīng)用程序開始執(zhí)行,觀察其輸出如圖13。圖1310.待Hello.exe執(zhí)行完畢后可以重復(fù)第8步,或者結(jié)束此次調(diào)試。3 練習(xí)通過編程的方式讓應(yīng)用程序創(chuàng)建另一個應(yīng)用程序的進(jìn)程使用OS Lab打開本實(shí)驗(yàn)文件夾中的NewProc.c文件(將此文件拖動到OS Lab窗口中釋放即可),仔細(xì)閱讀此文件中的源代碼和注釋,main函數(shù)的流程圖可以參見圖3。按照下面的步驟查看應(yīng)用程序創(chuàng)建另一個應(yīng)

5、用程序的進(jìn)程的執(zhí)行結(jié)果:1. 使用NewProc.c文件中的源代碼替換之前創(chuàng)建的EOS應(yīng)用程序項(xiàng)目中的EOSApp.c文件內(nèi)的源代碼。(去掉Newproc.h,保留原來的EOSApp.h)2. 按F7生成修改后的EOS應(yīng)用程序項(xiàng)目。3. 按F5啟動調(diào)試。OS Lab會首先彈出一個調(diào)試異常對話框如圖14。4. 在調(diào)試異常對話框中選擇“否”,繼續(xù)執(zhí)行結(jié)果如圖15。A圖14圖155. 激活虛擬機(jī)窗口查看應(yīng)用程序輸出的內(nèi)容,如圖16。可以看到父進(jìn)程(EOSApp.exe)首先開始執(zhí)行并輸出內(nèi)容,父進(jìn)程創(chuàng)建了子進(jìn)程阿(Hello.exe)后,子進(jìn)程開始執(zhí)行并輸出內(nèi)容,待子進(jìn)程結(jié)束后父進(jìn)程再繼續(xù)執(zhí)行。圖1

6、66. 結(jié)束此次調(diào)試。main函數(shù)流程圖4 調(diào)試CreateProcess函數(shù)按照下面的步驟調(diào)試CreateProcess函數(shù)創(chuàng)建進(jìn)程的過程:1. 按F5啟動調(diào)試EOS應(yīng)用程序,OS Lab會首先彈出一個調(diào)試異常對話框。2. 選擇“是”調(diào)試異常,調(diào)試會中斷。3. 在main函數(shù)中調(diào)用CreateProcess函數(shù)的代碼行(第56行)添加一個斷點(diǎn)如圖17。圖174. 按F5繼續(xù)調(diào)試,在斷點(diǎn)處中斷如圖18。圖185. 按F11調(diào)試進(jìn)入CreateProcess函數(shù)如圖19。此時已經(jīng)開始進(jìn)入EOS內(nèi)核進(jìn)行調(diào)試。圖19EOS應(yīng)用程序eosapp.exe創(chuàng)建的進(jìn)程從圖4中可以看到,當(dāng)EOS應(yīng)用程序eos

7、app.exe存儲在磁盤上的時候,它是靜態(tài)的,只包含應(yīng)用程序的指令和數(shù)據(jù)。而創(chuàng)建進(jìn)程后,進(jìn)程不但包含應(yīng)用程序的指令和數(shù)據(jù),也會包含操作系統(tǒng)內(nèi)核的指令和數(shù)據(jù)。同時也說明了一個進(jìn)程可以包含多個程序??梢园凑障旅娴牟襟E來分別驗(yàn)證應(yīng)用程序和操作系統(tǒng)內(nèi)核在進(jìn)程的4G虛擬地址空間中所處的位置:1. 由于此時在內(nèi)核的CreateProcess函數(shù)內(nèi)中斷執(zhí)行,所以在“調(diào)試”菜單的“窗口”中選擇“反匯編”,會在“反匯編”窗口中顯示CreateProcess函數(shù)的指令對應(yīng)的反匯編代碼如圖20?!胺磪R編”窗口的左側(cè)顯示的是指令所在的虛擬地址。可以看到所有指令的虛擬地址都大于0x80000000,說明內(nèi)核處于高2G的

8、虛擬地址空間中。 圖202. 在“調(diào)用堆?!贝翱谥须p擊main函數(shù)項(xiàng)如圖21,設(shè)置main函數(shù)的調(diào)用堆棧幀為活動的。在“反匯編”窗口中查看main函數(shù)的指令所在的虛擬地址都是小于0x80000000如圖22,說明應(yīng)用程序處于低2G的虛擬地址空間中。圖21圖223. 關(guān)閉“反匯編”窗口。接下來觀察CreateProcess函數(shù)的源代碼,可以看到此函數(shù)只是調(diào)用了EOS內(nèi)核函數(shù)PsCreateProcess并將創(chuàng)建進(jìn)程所用到的參數(shù)傳遞給了此函數(shù)。所以,按F11可以調(diào)試進(jìn)入create.c文件中的PsCreateProcess函數(shù)結(jié)果如圖23,在此函數(shù)中才開始執(zhí)行創(chuàng)建進(jìn)程的各項(xiàng)操作。圖235 調(diào)試Ps

9、CreateProcess函數(shù)創(chuàng)建進(jìn)程最主要的操作就是創(chuàng)建進(jìn)程控制塊并初始化其中的各種信息(也就是為進(jìn)程分配各種資源)。所以在PsCreateProcess函數(shù)中首先調(diào)用了PspCreateProcessEnvironment函數(shù)來創(chuàng)建進(jìn)程控制塊。調(diào)試PspCreateProcessEnvironment函數(shù)的步驟如下:1. 在PsCreateProcess函數(shù)中找到調(diào)用PspCreateProcessEnvironment函數(shù)的代碼行(create.c文件的第163行)并添加一個斷點(diǎn)如圖24。圖242. 按F5繼續(xù)調(diào)試,到此斷點(diǎn)處中斷如圖25。圖253. 按F11調(diào)試進(jìn)入PspCreateP

10、rocessEnvironment函數(shù)結(jié)果如圖26。圖26由于PspCreateProcessEnvironment函數(shù)的主要功能就是創(chuàng)建進(jìn)程控制塊并初始化其中的部分信息,所以在此函數(shù)的開始,定義了一個進(jìn)程控制塊的指針變量NewProcess。在此函數(shù)中查找到創(chuàng)建進(jìn)程控制塊的代碼行(create.c文件的第418行)如圖27。Status = ObCreateObject( PspProcessType,NULL,sizeof(PROCESS) + ImageNameSize + CmdLineSize,0,(PVOID*)&NewProcess );圖27這里的ObCreateObject函

11、數(shù)在由EOS內(nèi)核管理的內(nèi)存中創(chuàng)建了一個新的進(jìn)程控制塊(也就是分配了一塊內(nèi)存),并由NewProcess返回了進(jìn)程控制塊的指針(也就是所分配內(nèi)存的起始地址)。 按照下面的步驟調(diào)試進(jìn)程控制塊的創(chuàng)建過程:1. 在調(diào)用ObCreateObject函數(shù)的代碼行(create.c文件的第418行)添加一個斷點(diǎn)如圖28。圖282. 按F5繼續(xù)調(diào)試,到此斷點(diǎn)處中斷如圖29。 圖293. 按F10執(zhí)行此函數(shù)后中斷如圖30。圖304. 此時為了查看進(jìn)程控制塊中的信息,將表達(dá)式*NewProcess添加到“監(jiān)視”窗口中。5. 將鼠標(biāo)移動到“監(jiān)視”窗口中此表達(dá)式的“值”屬性上,會彈出一個臨時窗口,在臨時窗口中會按照進(jìn)

12、程控制塊的結(jié)構(gòu)顯示各個成員變量的值(可以參考PROCESS結(jié)構(gòu)體的定義)。由于只是新建了進(jìn)程控制塊,還沒有初始化其中成員變量,所以值都為0,如圖31。圖31接下來調(diào)試初始化進(jìn)程控制塊中各個成員變量的過程:1. 首先創(chuàng)建進(jìn)程的地址空間。在代碼行(create.c文件的第437行)NewProcess-Pas = MmCreateProcessAddressSpace();處添加一個斷點(diǎn)如圖32。圖322. 按F5繼續(xù)調(diào)試,到此斷點(diǎn)處中斷如圖33。圖333. 按F10執(zhí)行此行代碼后中斷結(jié)果如圖34。圖344. 在“監(jiān)視”窗口中查看進(jìn)程控制塊的成員變量Pas的值已經(jīng)不再是0,如圖35。說明已經(jīng)初始化

13、了進(jìn)程的4G虛擬地址空間。圖355. 使用F10一步步調(diào)試PspCreateProcessEnvironment函數(shù)中后面的代碼,在調(diào)試的過程中根據(jù)執(zhí)行的源代碼,查看“監(jiān)視”窗口中*NewProcess表達(dá)式的值,觀察進(jìn)程控制塊中哪些成員變量是被哪些代碼初始化的,哪些成員變量還沒有被初始化。6. 當(dāng)從PspCreateProcessEnvironment函數(shù)返回到PsCreateProcess函數(shù)后,停止按F10。此時“監(jiān)視”窗口中已經(jīng)不能再顯示表達(dá)式*NewProcess的值了,在PsCreateProcess函數(shù)中是使用ProcessObject指針指向進(jìn)程控制塊的,所以將表達(dá)式*Proc

14、essObject添加到“監(jiān)視”窗口中就可以繼續(xù)觀察新建進(jìn)程控制塊中的信息。7. 接下來繼續(xù)使用F10一步步調(diào)試PsCreateProcess函數(shù)中的代碼,同樣要注意觀察執(zhí)行后的代碼修改了進(jìn)程控制塊中的哪些成員變量。當(dāng)調(diào)試到PsCreateProcess函數(shù)的最后一行代碼時,查看進(jìn)程控制塊中的信息,此時所有的成員變量都已經(jīng)被初始化了(注意觀察成員ImageName的值)。8. 按F5繼續(xù)執(zhí)行,EOS內(nèi)核會為剛剛初始化完畢的進(jìn)程控制塊新建一個進(jìn)程。激活虛擬機(jī)窗口查看新建進(jìn)程執(zhí)行的結(jié)果如圖36。圖369. 在OS Lab中選擇“調(diào)試”菜單中的“停止調(diào)試”結(jié)束此次調(diào)試。6 練習(xí)通過編程的方式創(chuàng)建應(yīng)用程序的多個進(jìn)程使用OS Lab打開本實(shí)驗(yàn)文件夾中的參考源代碼文件NewTwoProc.c,仔細(xì)閱讀此文件中的源代碼。使用NewTwoProc.c文件中的源代碼替換EOS應(yīng)用程序項(xiàng)目中的EOSApp.c文件內(nèi)的源代碼,并查看多個進(jìn)程并發(fā)執(zhí)行的結(jié)果。同時創(chuàng)建應(yīng)用程序的多個進(jìn)程4、 實(shí)驗(yàn)結(jié)果與分析 1、基本完

溫馨提示

  • 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論