版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 課程設(shè)計(jì)</b></p><p> 題目: 操作系統(tǒng)課程設(shè)計(jì) </p><p> 學(xué) 部 信息科學(xué)與工程學(xué)部 </p><p> 學(xué)科門(mén)類 工學(xué) </p><p>
2、; 專 業(yè) 網(wǎng)絡(luò)工程 </p><p> 學(xué) 號(hào) </p><p> 姓 名 </p><p> 指導(dǎo)教師 </p><p><b> 年 月
3、 日</b></p><p><b> 目 錄</b></p><p><b> 一 基本思想1</b></p><p> 1.1硬件工作的模擬1</p><p> 1.1.1中央處理器的模擬1</p><p> 1.1.2主要寄存器的模擬1&
4、lt;/p><p> 1.1.3中斷的模擬1</p><p> 1.1.4 時(shí)鐘的模擬1</p><p> 1.2進(jìn)程控制塊2</p><p><b> 1.3進(jìn)程調(diào)度2</b></p><p><b> 1.4進(jìn)程控制2</b></p><
5、;p> 1.5屏幕顯示要求 ……………………………………………………………3</p><p> 二 定義的公共變量或數(shù)據(jù)結(jié)構(gòu)(給出注釋)4</p><p> 2.1主要公共變量4</p><p> 2.1.1關(guān)于進(jìn)程4</p><p> 2.1.2時(shí)間片4</p><p> 2.1.3定時(shí)器
6、4</p><p> 2.2主要數(shù)據(jù)結(jié)構(gòu)4</p><p> 三 各部分主要函數(shù)的過(guò)程描述6</p><p> 3.1中央處理器的模擬6</p><p> 3.2中斷的模擬6</p><p> 3.3時(shí)鐘的模擬7</p><p> 3.4 進(jìn)程創(chuàng)建create8</
7、p><p> 3.5進(jìn)程阻塞block8</p><p><b> 四 運(yùn)行截圖9</b></p><p><b> 4.1添加進(jìn)程9</b></p><p> 4.2運(yùn)行進(jìn)程10</p><p> 4.3 結(jié)束進(jìn)程2</p><p>
8、<b> 五 總 結(jié)13</b></p><p><b> 一 基本思想</b></p><p> 1.1硬件工作的模擬</p><p> 1.1.1中央處理器的模擬</p><p> 用函數(shù)CPU()(該函數(shù)不能有參數(shù))模擬中央處理器。該函數(shù)主要負(fù)責(zé)解釋“可執(zhí)行文件”中的命令。<
9、;/p><p> x=?; 給x賦值一位數(shù)</p><p><b> x++; x加1</b></p><p><b> x--; x減1</b></p><p> !??; 第一個(gè)?為A,B,C中某個(gè)設(shè)備,第二個(gè)?為一位數(shù),表示使用設(shè)備的時(shí)間;</p><p>
10、 end. 表示進(jìn)程結(jié)束,同時(shí)將結(jié)果寫(xiě)入運(yùn)行結(jié)果框中,其中包括進(jìn)程名和最終結(jié)果。</p><p> CPU只能解釋指令寄存器IR中的指令。一個(gè)進(jìn)程的運(yùn)行時(shí)要根據(jù)進(jìn)程執(zhí)行的位置,將對(duì)應(yīng)的指令存放到指令寄存器中。</p><p> 1.1.2主要寄存器的模擬</p><p> 用全局變量模擬重要寄存器,如CPU重要寄存器,程序狀態(tài)寄存器PSW、指令寄存器IR,程序
11、計(jì)數(shù)器PC,數(shù)據(jù)緩沖寄存器DR等。</p><p> 1.1.3中斷的模擬</p><p> I.中斷的發(fā)現(xiàn)應(yīng)該是硬件的工作,這里在函數(shù)CPU中加檢測(cè)PSW的方式來(lái)模擬</p><p> 在CPU()函數(shù)中,每執(zhí)行一條指令之前,先檢查PSW,判斷有無(wú)中斷,若有進(jìn)行中斷處理,然后再運(yùn)行解釋指令。CPU函數(shù)應(yīng)該不斷循環(huán)執(zhí)行的。</p><p&g
12、t; ?、颍M中斷的種類和中斷處理方式:</p><p> 程序結(jié)束(執(zhí)行指令end形成的中斷,軟中斷):將結(jié)果寫(xiě)入運(yùn)行結(jié)果框體中,其中包括運(yùn)行指令的指令名和指令的值,調(diào)用進(jìn)程撤銷原語(yǔ)撤銷進(jìn)程,然后進(jìn)行進(jìn)程調(diào)度;</p><p> 時(shí)間片到(當(dāng)相對(duì)始終寄存器值減到0時(shí)):將正在運(yùn)行進(jìn)程的CPU現(xiàn)場(chǎng)保存在進(jìn)程控制塊中,然后進(jìn)行進(jìn)程調(diào)度;</p><p> I/
13、O中斷(設(shè)備完成輸入輸出):將輸入輸出完成的進(jìn)程喚醒,將等待該設(shè)備的一個(gè)進(jìn)程同時(shí)喚醒。</p><p> 1.1.4時(shí)鐘的模擬</p><p> 系統(tǒng)中的絕對(duì)時(shí)鐘和相對(duì)時(shí)鐘用全局變量模擬。絕對(duì)時(shí)鐘用來(lái)記錄進(jìn)程運(yùn)行后直到軟件關(guān)閉的的時(shí)間,相對(duì)時(shí)鐘用來(lái)存放進(jìn)程可執(zhí)行的時(shí)間片,在進(jìn)程調(diào)度時(shí)設(shè)置初值,隨系統(tǒng)時(shí)間的增值1而減值1,減到0時(shí),發(fā)出時(shí)鐘中斷。</p><p>
14、<b> 1.2進(jìn)程控制塊</b></p><p> 進(jìn)程控制塊內(nèi)容包括進(jìn)程標(biāo)識(shí)符、處理機(jī)狀態(tài)信息(如主要寄存器內(nèi)容)、進(jìn)程調(diào)度信息(如進(jìn)程狀態(tài)、進(jìn)程優(yōu)先級(jí)、進(jìn)程調(diào)度所需的其他信息、阻塞原因)、進(jìn)程控制信息(如進(jìn)程程序和數(shù)據(jù)的地址)。本模擬系統(tǒng)最多容納10個(gè)進(jìn)程塊。</p><p> PCB區(qū)域用數(shù)組模擬。</p><p> 進(jìn)程控制塊
15、根據(jù)內(nèi)容的不同組成不同的隊(duì)列:空白進(jìn)程控制塊鏈、就緒隊(duì)列和阻塞隊(duì)列,正在運(yùn)行的進(jìn)程只有一個(gè),系統(tǒng)初始時(shí)只有空白進(jìn)程控制塊鏈。</p><p><b> 1.3進(jìn)程調(diào)度</b></p><p> 1.進(jìn)程調(diào)度在模擬系統(tǒng)中,采用時(shí)間片輪轉(zhuǎn)調(diào)度算法,時(shí)間片可設(shè)定。</p><p> 2.進(jìn)程調(diào)度函數(shù)的主要工作是:將正在運(yùn)行的進(jìn)程保存在該進(jìn)程對(duì)應(yīng)
16、進(jìn)程控制塊中;從就緒隊(duì)列中選擇一個(gè)進(jìn)程;將這個(gè)進(jìn)程中進(jìn)程控制塊中記錄的各寄存器內(nèi)容恢復(fù)到CPU各個(gè)寄存器內(nèi)。</p><p><b> 3.閑逛進(jìn)程</b></p><p> 建立一個(gè)閑逛進(jìn)程,當(dāng)就緒對(duì)列為空時(shí),系統(tǒng)調(diào)用該進(jìn)程運(yùn)行。當(dāng)有進(jìn)程就緒時(shí),就調(diào)度就緒進(jìn)程運(yùn)行。閑逛進(jìn)程什么也不做,只是起到系統(tǒng)能正常運(yùn)轉(zhuǎn)的作用。例如windows中的idle進(jìn)程。</p
17、><p><b> 1.4進(jìn)程控制</b></p><p> 建立四個(gè)函數(shù)模擬進(jìn)程創(chuàng)建、撤銷、阻塞和喚醒四個(gè)原語(yǔ)。</p><p> 1.進(jìn)程創(chuàng)建create</p><p> 進(jìn)程創(chuàng)建的主要工作是:</p><p> 第一步,申請(qǐng)空白進(jìn)程控制塊;</p><p>
18、 第二步,申請(qǐng)主存空間,申請(qǐng)成功,裝入主存;</p><p> 第三步,初始化進(jìn)程控制塊;</p><p> 第四步,將進(jìn)程鏈入就緒隊(duì)列。</p><p> 2.進(jìn)程撤銷destory</p><p> 進(jìn)程撤銷的主要工作是:</p><p> 第一步,回收進(jìn)程所占內(nèi)存資源;</p><p
19、> 第二步,回收進(jìn)程控制塊;</p><p> 第三步,在屏幕上顯示進(jìn)程執(zhí)行結(jié)果,進(jìn)程撤銷</p><p> 3.進(jìn)程阻塞block</p><p> 進(jìn)程阻塞的主要工作是:</p><p> 第一步,保存運(yùn)行進(jìn)程的CPU現(xiàn)場(chǎng);</p><p> 第二步,修改進(jìn)程狀態(tài);</p><
20、p> 第三步,將進(jìn)程鏈入對(duì)應(yīng)的阻塞隊(duì)列,然后轉(zhuǎn)向進(jìn)程調(diào)度。</p><p><b> 4.進(jìn)程的喚醒</b></p><p> 進(jìn)程喚醒的主要工作是將進(jìn)程由阻塞隊(duì)列中摘下,修改進(jìn)程狀態(tài)為就緒,然后鏈入就緒隊(duì)列。</p><p><b> 1.5屏幕顯示要求</b></p><p>&l
21、t;b> 屏幕顯示要求包括:</b></p><p><b> 顯示系統(tǒng)時(shí)鐘;</b></p><p> 顯示正在運(yùn)行的進(jìn)程的進(jìn)程名、運(yùn)行的指令、中間結(jié)果、相對(duì)時(shí)鐘內(nèi)容;</p><p> 顯示就緒隊(duì)列中進(jìn)程名;</p><p> 顯示阻塞隊(duì)列中進(jìn)程名,等待時(shí)間。</p><
22、;p> 二 定義的公共變量或數(shù)據(jù)結(jié)構(gòu)(給出注釋)</p><p><b> 2.1主要公共變量</b></p><p><b> 2.1.1關(guān)于進(jìn)程</b></p><p> 三個(gè)編輯框分別對(duì)應(yīng)三個(gè)變量:</p><p> CString m_jcming //顯示進(jìn)程
23、名</p><p> CString m_zhiling //顯示當(dāng)前執(zhí)行指令</p><p> CString m_jieguo //顯示中間結(jié)果</p><p> 三個(gè)列表框分別對(duì)應(yīng)三個(gè)變量:</p><p> ClistBox m_jiuxu //就緒隊(duì)列</p><p>
24、; ClistBox m_zuse //阻塞隊(duì)列</p><p> ClistBox m_jieshu //運(yùn)行結(jié)束的隊(duì)列</p><p> 還有一個(gè)編輯框用來(lái)輸入指令:</p><p> CString m_shuruzhiling //得到命令文件</p><p><b> 2.1.2時(shí)間片&
25、lt;/b></p><p> 編輯框IDC_EDIT_shijianpian</p><p> 對(duì)應(yīng)變量int m_timelength //時(shí)間片大小</p><p><b> 2.1.3定時(shí)器</b></p><p> 靜態(tài)文本框IDC_CSTATIC</p><p>
26、 對(duì)應(yīng)變量CStatic m_cpushijian //顯示時(shí)間</p><p><b> 2.2主要數(shù)據(jù)結(jié)構(gòu)</b></p><p><b> 進(jìn)程控制塊PCB:</b></p><p> enum event_source {null,timeout,waiting,processing};//枚舉變量包含進(jìn)
27、程狀態(tài)</p><p> enum event_type {a,b,c};//枚舉變量包含阻塞請(qǐng)求資源</p><p> typedef struct pcb</p><p><b> {</b></p><p> CString pcb_name;// 進(jìn)程名</p><p> int
28、 pcb_no;//進(jìn)程號(hào)</p><p> CString *command;//進(jìn)程文件</p><p> int linesnum;//進(jìn)程文件指令數(shù)</p><p> int current;//當(dāng)前指針</p><p> int result;//計(jì)算結(jié)果</p><p> enum event_s
29、ource event;//事件 </p><p> enum event_type eventtype;//阻塞事件請(qǐng)求的資源</p><p> int event_time;//使用資源時(shí)間</p><p> pcb *link;//pcb指針指向下一個(gè)節(jié)點(diǎn)</p><p> }pcb; </p>&
30、lt;p> 三 各部分主要函數(shù)的過(guò)程描述</p><p> 3.1中央處理器的模擬</p><p> public CPU {</p><p><b> 解釋可執(zhí)行性指令</b></p><p> 定義IR[4]指令寄存器,通過(guò)每四個(gè)字符串的截取來(lái)解釋可執(zhí)行指令</p><p>
31、; 當(dāng)運(yùn)行指令時(shí),通過(guò)判斷</p><p> IF(指令是!??格式)</p><p><b> {</b></p><p> 則進(jìn)程阻塞,把進(jìn)程放入阻塞隊(duì)列,</p><p><b> 記錄阻塞時(shí)間</b></p><p><b> 保存CPU現(xiàn)場(chǎng)&l
32、t;/b></p><p><b> }</b></p><p> ELSE IF(指令是i=?格式)</p><p><b> {</b></p><p><b> 則為賦值語(yǔ)句</b></p><p><b> }<
33、/b></p><p> ELSE IF(指令是i++格式)</p><p><b> {</b></p><p> 則指令執(zhí)行加1操作,此時(shí)顯示到中間結(jié)果框體中</p><p><b> }</b></p><p> ELSE IF(指令是i--格式)&
34、lt;/p><p><b> {</b></p><p> 則指令執(zhí)行減一操作,此時(shí)顯示到中間結(jié)果框體中</p><p><b> }</b></p><p><b> ELSE </b></p><p><b> {</b>
35、</p><p> 則由于指令格式不符合要求,運(yùn)行出錯(cuò)。</p><p><b> }</b></p><p><b> 3.2中斷的模擬</b></p><p><b> 1.時(shí)間片中斷</b></p><p> public onTimer
36、(){</p><p> 將執(zhí)行的進(jìn)程插入到就緒隊(duì)列尾部;</p><p> 應(yīng)保存好此進(jìn)程的CPU現(xiàn)場(chǎng);</p><p> 再?gòu)木途w隊(duì)列頭部取出一個(gè)新的進(jìn)程執(zhí)行;</p><p> 調(diào)用:OnTimer(UINT nIDEvent)函數(shù)</p><p><b> }</b></p
37、><p><b> 2.申請(qǐng)?jiān)O(shè)備中斷</b></p><p> public Block()</p><p><b> {</b></p><p> 將進(jìn)程放入阻塞隊(duì)列中;</p><p> 保存好此進(jìn)程的CPU現(xiàn)場(chǎng)信息;</p><p>
38、再?gòu)木途w隊(duì)列頭部取出一個(gè)新的進(jìn)程執(zhí)行;</p><p> 調(diào)用:Block(PCB *pcb)函數(shù)</p><p><b> }</b></p><p><b> 3.程序正常結(jié)束</b></p><p> public onBUTTONjieshu()</p><p&
39、gt;<b> {</b></p><p> 進(jìn)程正常結(jié)束,則把進(jìn)程名和運(yùn)行結(jié)果顯示到最終結(jié)果顯示框中;</p><p> 再?gòu)木途w隊(duì)列頭部取出一個(gè)新的進(jìn)程執(zhí)行;</p><p> 調(diào)用:OnBUTTONjieshu()函數(shù)</p><p><b> } </b></p>
40、<p> 3.3進(jìn)程創(chuàng)建create</p><p><b> 輸入指令</b></p><p> IF (文本域?yàn)榭眨?lt;/p><p><b> {</b></p><p> 命令文件有誤,請(qǐng)檢查或仔細(xì)閱讀幫助</p><p><b> ?。?
41、lt;/b></p><p><b> ELSE</b></p><p><b> ?。?lt;/b></p><p><b> 提交給進(jìn)程管理</b></p><p><b> ?。?lt;/b></p><p> 在進(jìn)程管理類中
42、,初始化進(jìn)程控制塊PCB類</p><p> public class PCB</p><p><b> {</b></p><p> id 進(jìn)程的標(biāo)識(shí)符</p><p> state 進(jìn)程當(dāng)前狀態(tài), 就緒0, 執(zhí)行1, 阻塞-1.</p><p> name 進(jìn)程的名稱 </p
43、><p> next 進(jìn)程隊(duì)列指針 , PCB鏈中下一個(gè)PCB的地址,當(dāng)NEXT=-1時(shí),表示隊(duì)尾。</p><p> time 進(jìn)程阻塞的時(shí)間</p><p><b> }</b></p><p><b> 將進(jìn)程鏈入就緒隊(duì)列</b></p><p> IF(判斷插入
44、的進(jìn)程數(shù)是否超過(guò)10個(gè))</p><p><b> {</b></p><p> 顯示的進(jìn)程名數(shù)字混亂</p><p><b> }</b></p><p><b> IF(非空)</b></p><p><b> {</b&g
45、t;</p><p> 則把進(jìn)程插入到隊(duì)列尾部</p><p><b> }</b></p><p> 3.4進(jìn)程阻塞block</p><p> 當(dāng)申請(qǐng)?jiān)O(shè)備時(shí),進(jìn)行阻塞</p><p> public Block()</p><p><b> {&
46、lt;/b></p><p> 將進(jìn)程放入阻塞隊(duì)列中;</p><p> 保存好此進(jìn)程的CPU現(xiàn)場(chǎng)信息;</p><p> 再?gòu)木途w隊(duì)列頭部取出一個(gè)新的進(jìn)程執(zhí)行;</p><p> 調(diào)用:Block(PCB *pcb)函數(shù)。</p><p><b> }</b></p>
47、<p><b> ?。?5進(jìn)程的喚醒</b></p><p> 阻塞時(shí)間結(jié)束,則進(jìn)程喚醒</p><p> public wakeUp()</p><p><b> {</b></p><p> 阻塞隊(duì)列的此進(jìn)程被喚醒;</p><p> 將此進(jìn)程在插
48、入到就緒隊(duì)列。 </p><p><b> }四 運(yùn)行截圖</b></p><p><b> 4.1添加進(jìn)程</b></p><p><b> 添加進(jìn)程不能為空</b></p><p><b> 圖 1</b></p>&l
49、t;p><b> 添加合法的進(jìn)程</b></p><p><b> 圖2</b></p><p> 最多添加的進(jìn)程不能超過(guò)10個(gè)</p><p><b> 圖 3</b></p><p><b> 4.2運(yùn)行進(jìn)程</b></p>
50、<p> 以添加4個(gè)進(jìn)程為例,進(jìn)行演示</p><p> 點(diǎn)擊運(yùn)行按鈕,執(zhí)行指令的全過(guò)程如下圖片:</p><p><b> 圖 4</b></p><p> 把五個(gè)進(jìn)程插入就緒隊(duì)列,點(diǎn)擊運(yùn)行按鈕,此時(shí)為運(yùn)行的中間過(guò)程</p><p><b> 圖 5</b></p&g
51、t;<p> 進(jìn)程執(zhí)行完畢,最終結(jié)果在結(jié)束進(jìn)程一欄顯示</p><p><b> 圖6</b></p><p> 四個(gè)進(jìn)程全部執(zhí)行完畢。</p><p><b> 4.3 結(jié)束進(jìn)程</b></p><p> 當(dāng)按下結(jié)束按鈕后,將清空所有框體中的內(nèi)容。</p>&
52、lt;p><b> 五 總 結(jié)</b></p><p> 本課程設(shè)計(jì)主要是針對(duì)進(jìn)程管理,在做的過(guò)程中主要是按照面向?qū)ο蟮脑O(shè)計(jì)展開(kāi)的,可能有些內(nèi)容放錯(cuò)了位置,與操作系統(tǒng)的原理可能有些細(xì)微的偏差。</p><p> 由于自己頭一次編寫(xiě)這么大的程序,也是第一次對(duì)操作系統(tǒng)進(jìn)行模擬,對(duì)操作系統(tǒng)的原理可能理解的還不夠透徹,如果發(fā)現(xiàn)錯(cuò)誤,真誠(chéng)的希望老師指正。</
溫馨提示
- 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ù)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 操作系統(tǒng)課程設(shè)計(jì)-- 操作系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 內(nèi)存管理(操作系統(tǒng))操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)題目
- 操作系統(tǒng)課程設(shè)計(jì)報(bào)告
- 操作系統(tǒng)課程設(shè)計(jì)論文
- 操作系統(tǒng)課程設(shè)計(jì) (4)
- 操作系統(tǒng)課程設(shè)計(jì)1
- 課程設(shè)計(jì)報(bào)告--操作系統(tǒng)
- linux操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)報(bào)告
- 操作系統(tǒng)原理課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)--模擬操作系統(tǒng)的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)報(bào)告
- 操作系統(tǒng)課程設(shè)計(jì)1
評(píng)論
0/150
提交評(píng)論