版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 《操作系統(tǒng)》課程設(shè)計(jì)</p><p> 題目:進(jìn)程通信與進(jìn)程同步機(jī)制實(shí)踐</p><p> 學(xué)院名稱: 計(jì)算機(jī)科學(xué)與通信工程學(xué)院 </p><p><b> 班級(jí)學(xué)號(hào): </b></p><p><b> 學(xué)生姓名: </b></p>&l
2、t;p> 教師姓名: </p><p> 教師職稱: </p><p> 2016年 1 月8日</p><p><b> 目錄</b></p><p><b> 一 課程設(shè)計(jì)內(nèi)容</b></p><p>&
3、lt;b> 二 開(kāi)發(fā)環(huán)境</b></p><p><b> 二 原理</b></p><p> 五 主要數(shù)據(jù)結(jié)構(gòu)和流程</p><p> 六 原語(yǔ)對(duì)應(yīng)的函數(shù)及算法</p><p><b> 七 測(cè)試結(jié)果與分析</b></p><p><b&g
4、t; 八 總結(jié)</b></p><p><b> 九 源程序清單</b></p><p><b> 一課程設(shè)計(jì)的內(nèi)容</b></p><p><b> 【設(shè)計(jì)內(nèi)容】</b></p><p> 某銀行提供6個(gè)服務(wù)窗口(3個(gè)對(duì)私服務(wù)窗口,2個(gè)對(duì)公服務(wù)窗口,1個(gè)
5、理財(cái)服務(wù)窗口、一臺(tái)取號(hào)機(jī)和20個(gè)供顧客等待的座位。顧客到達(dá)銀行時(shí),若有空座位,則到取號(hào)機(jī)上領(lǐng)取一個(gè)號(hào),等待叫號(hào);若沒(méi)有空座位,則在門(mén)外等待或離開(kāi)。取號(hào)機(jī)每次僅允許一位顧客使用,有對(duì)公、對(duì)私和理財(cái)三類(lèi)號(hào),每位顧客只能選取其中一個(gè)。當(dāng)營(yíng)業(yè)員空閑時(shí),通過(guò)叫號(hào)選取一位顧客,并為其服務(wù)。</p><p><b> 【說(shuō)明】</b></p><p> (1)可模擬設(shè)立一個(gè)服務(wù)
6、時(shí)間區(qū)間如9:00-17:00,也可限定最大服務(wù)人數(shù);</p><p> (2)顧客達(dá)到時(shí)間隨機(jī),辦理對(duì)私、對(duì)公、理財(cái)業(yè)務(wù)隨機(jī),每位顧客服務(wù)時(shí)間可設(shè)定在一定范圍內(nèi)。這些都可通過(guò)隨機(jī)數(shù)產(chǎn)生。</p><p> (3)取號(hào)時(shí)顧客拿到的號(hào)含有號(hào)碼和等待的人數(shù),例如A、B、C分別代表對(duì)私、對(duì)公、理財(cái),“號(hào)碼:A05,有2人等待”表示取的是對(duì)私服務(wù)號(hào),編號(hào)是05,有2人等待辦理對(duì)私業(yè)務(wù)。<
7、/p><p> (4)成績(jī)?cè)u(píng)定:平時(shí)占60%,實(shí)驗(yàn)報(bào)告占40%;其中平時(shí)60%包括考勤和學(xué)習(xí)態(tài)度、學(xué)習(xí)積極性等占20%,兩次檢查,每次檢查各占20%。</p><p><b> 【檢查說(shuō)明】</b></p><p> 第一次檢查:時(shí)間18周周三-四,檢查同步與互斥算法與API熟悉情況</p><p> 第二次檢查:時(shí)
8、間18周周五上午與晚上,檢查最終程序完成情況。</p><p><b> 【要求】</b></p><p> 說(shuō)明設(shè)置哪些信號(hào)量?信號(hào)量的含義和初始值是什么?并用信號(hào)量和P、V操作寫(xiě)出進(jìn)程的同步算法。(注:該內(nèi)容包含在設(shè)計(jì)報(bào)告中,并在第一次檢查時(shí)檢查)</p><p> 查閱并自學(xué)進(jìn)程、線程的創(chuàng)建與撤銷(xiāo)、信號(hào)量、P操作、V操作等相關(guān)原語(yǔ)的
9、系統(tǒng)調(diào)用。(注:該內(nèi)容包含在設(shè)計(jì)報(bào)告中,并在第一次檢查時(shí)檢查)</p><p> 在Linux或Windows或Unix環(huán)境下,采用系統(tǒng)調(diào)用中的進(jìn)程或線程的創(chuàng)建與撤銷(xiāo)、信號(hào)量、P操作、V操作,編程解決上述問(wèn)題,并完成調(diào)試與測(cè)試工作。(注:該內(nèi)容包含將并在第二次檢查時(shí)檢查)</p><p> 打印:(注意:由于多個(gè)進(jìn)程共享一個(gè)顯示器或文件,需要互斥訪問(wèn))</p><p
10、> 各進(jìn)程的初始狀態(tài)信息;</p><p><b> 中間狀態(tài)變化信息;</b></p><p><b> 最終狀態(tài)信息。</b></p><p> 例如,顧客到達(dá)時(shí)的時(shí)間狀態(tài)信息,領(lǐng)取的號(hào)碼信息,等待時(shí)間,接收服務(wù)的服務(wù)窗口信息、服務(wù)時(shí)間,離開(kāi)時(shí)間等信息。</p><p><b
11、> 目的</b></p><p> 通過(guò)課程設(shè)計(jì)模擬銀行辦理業(yè)務(wù)的情景,使用pv操作實(shí)現(xiàn)互斥與同步。來(lái)進(jìn)一步熟悉課堂上講授的pv操作原語(yǔ),掌握進(jìn)程的互斥與同步的知識(shí)。</p><p><b> 二開(kāi)發(fā)環(huán)境</b></p><p> windows操作系統(tǒng),</p><p><b>
12、使用Java語(yǔ)言,</b></p><p> 在eclipse上實(shí)現(xiàn)</p><p><b> 三原理及算法</b></p><p> 1用一個(gè)線程來(lái)模擬一位客戶,客戶到來(lái)時(shí)間,離開(kāi)時(shí)間,都是通過(guò)獲取系統(tǒng)的時(shí)間來(lái)體現(xiàn)。中間等待及辦理業(yè)務(wù)的時(shí)間則通過(guò)產(chǎn)生的一定范圍的隨機(jī)數(shù)對(duì)線程進(jìn)行睡眠來(lái)模擬的</p><p&
13、gt;<b> 2總共分為三個(gè)類(lèi),</b></p><p> 第一個(gè)類(lèi)是包括主函數(shù)的類(lèi),用來(lái)開(kāi)啟程序并創(chuàng)建線程對(duì)象。</p><p> 第二個(gè)類(lèi)是線程類(lèi),包括線程的定義和線程的方法run方法,在run方法內(nèi)對(duì)實(shí)現(xiàn)主要程序的功能的函數(shù)進(jìn)行調(diào)用。</p><p> 第三個(gè)類(lèi),就是存儲(chǔ)的需要用到的主要變量,計(jì)數(shù)器,及實(shí)現(xiàn)程序功能的三個(gè)函數(shù),供
14、所有的線程公用。三個(gè)函數(shù)。</p><p> 第一個(gè)函數(shù)進(jìn)行座位的檢測(cè),有座位則進(jìn)入銀行,沒(méi)有在在外等待,以及獲取此時(shí)運(yùn)行該線程的名字,作為一個(gè)客戶的標(biāo)識(shí),并通告該客戶到來(lái)及此時(shí)的時(shí)間。</p><p> 第二個(gè)函數(shù)實(shí)現(xiàn)取號(hào)功能,其中包括判斷取號(hào)機(jī)是否有人使用,取號(hào)時(shí)根據(jù)隨機(jī)數(shù)產(chǎn)生三種不同的票號(hào),同時(shí)該票號(hào)的內(nèi)容還包括票的序號(hào)和此類(lèi)票號(hào)對(duì)應(yīng)的服務(wù)窗口現(xiàn)在還有多少人在等待。</p&
15、gt;<p> 第三個(gè)函數(shù)是服務(wù)功能,包括根據(jù)票號(hào)判斷此時(shí)該類(lèi)窗口是否有已滿,滿了就等待,沒(méi)滿則去辦理業(yè)務(wù)。辦理業(yè)務(wù)通過(guò)產(chǎn)生隨機(jī)數(shù)對(duì)線程進(jìn)行休眠,客戶離開(kāi)時(shí),通告客戶的服務(wù)時(shí)間,及離開(kāi)的時(shí)間。</p><p> 四主要數(shù)據(jù)結(jié)構(gòu)和流程</p><p><b> 六個(gè)信號(hào)量</b></p><p> 一個(gè)代表大廳的座位,初值為
16、20。</p><p> 一個(gè)代表取號(hào)機(jī),初值為1,。</p><p> 三個(gè)窗口,初值分別為3,2,1。</p><p> 一個(gè)用來(lái)實(shí)現(xiàn)對(duì)記錄大廳人數(shù)的變量的互斥操作。</p><p><b> 四個(gè)變量</b></p><p> 一個(gè)代表辦理業(yè)務(wù)的總?cè)藬?shù)。</p>&l
17、t;p> 三個(gè)分別代表三個(gè)窗口的等待人數(shù)。</p><p> 票號(hào)的格式為服務(wù)+票號(hào)+等待人數(shù)。例如A-22-3表示辦理對(duì)私服務(wù),票號(hào)為22,該窗口還有3人在等待。</p><p> 等待時(shí)間,服務(wù)時(shí)間,均是調(diào)用函數(shù)產(chǎn)生隨機(jī)數(shù)。</p><p><b> 流程圖</b></p><p> 五原語(yǔ)對(duì)應(yīng)函數(shù)及
18、pv算法</p><p> 創(chuàng)建線程:繼承Thread類(lèi),實(shí)現(xiàn)run方法</p><p> 信號(hào)量semaphore</p><p> p操作:acquire</p><p> v操作:release</p><p> Semaphore Zcount ,Qcount,counta,countb,countc
19、,countx;</p><p> Zcount.value=20;</p><p> Qcount.value=1; </p><p> Counta.value=3;</p><p> Countb.value=2;</p><p> Countc.value=1;</p><p>
20、; Countx.value=1;</p><p><b> Process{</b></p><p> P(&zcount);{</p><p> p(&qcount);</p><p><b> 取票</b></p><p><b>
21、 A</b></p><p><b> B</b></p><p><b> C</b></p><p> Return A或者B或者C;</p><p> v(&qcount);</p><p><b> If(A){</b&g
22、t;</p><p> P(&counta);</p><p> V(&zcount);</p><p><b> 辦理服務(wù)</b></p><p> V(&counta);</p><p><b> }</b></p><
23、;p> Else if(B){</p><p> P(&countb);</p><p> V(&zcount);</p><p><b> 辦理服務(wù)</b></p><p> V(&countb);</p><p><b> }</b&g
24、t;</p><p><b> Else{</b></p><p> P(&countc);</p><p> V(&zcount);</p><p><b> 辦理服務(wù)</b></p><p> V(&countc);</p>
25、<p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> 六測(cè)試結(jié)果與分析</b></p><p> 分析:進(jìn)程的名字標(biāo)志客戶。</p><
26、p> 由于線程太快,設(shè)置的休眠時(shí)間較短,所以存在同一秒級(jí)有多個(gè)用戶到達(dá)。</p><p> 服務(wù)時(shí)間為1000,2000,3000毫秒隨機(jī)。</p><p> 到來(lái)及離開(kāi)都是分別獲取此時(shí)系統(tǒng)的時(shí)間。</p><p><b> 七總結(jié)</b></p><p> 經(jīng)過(guò)本次的實(shí)驗(yàn)對(duì)pv操作有了更進(jìn)一步的理解,從
27、更深層次了解了同步與互斥的原理及實(shí)現(xiàn)的過(guò)程。設(shè)計(jì)過(guò)程遇到了各種問(wèn)題。</p><p> 在設(shè)計(jì)pv操作時(shí)由于座位加上窗口共可以存放26個(gè)人,盡管信號(hào)量設(shè)置的是20,但是需要在每一個(gè)人申請(qǐng)到窗口時(shí)即釋放座位。就是在釋放窗口之前。</p><p> 在設(shè)計(jì)程序時(shí)關(guān)于每個(gè)線程共享的變量以及每個(gè)線程私有的變量的問(wèn)題,比如取到的號(hào)即為每個(gè)線程的私有變量。</p><p>
28、 最后經(jīng)過(guò)一周半的課程設(shè)計(jì)之后,對(duì)編程,解決問(wèn)題的能力,都有了一定的提升。</p><p><b> 九 源程序清單</b></p><p><b> 第一個(gè)類(lèi)</b></p><p> package bank1;</p><p> publicclass routine {</p
29、><p> publicstatic common comm =new common();</p><p> @SuppressWarnings("deprecation")</p><p> publicstaticvoid main(String[] args) {</p><p><b> inti;
30、</b></p><p> for (i=1;i<=20;i++){</p><p> client clii=new client(comm);</p><p> clii.start();</p><p><b> }</b></p><p><b> }
31、</b></p><p><b> }</b></p><p><b> 第二個(gè)類(lèi)</b></p><p> package bank1;</p><p> import bank1.common;</p><p> import java.util.R
32、andom;</p><p> import java.util.concurrent.Semaphore;</p><p> public class client extends Thread {</p><p> private common comm;</p><p> String result= new String();
33、</p><p> public client(common thiscomm) {</p><p> // TODO 自動(dòng)生成的構(gòu)造函數(shù)存根</p><p> comm=thiscomm;</p><p><b> }</b></p><p> public void run(){&
34、lt;/p><p> Random ran=new Random();</p><p><b> try {</b></p><p> sleep((ran.nextInt(6)+1)*2000);</p><p> } catch (InterruptedException e1) {</p><
35、;p> // TODO 自動(dòng)生成的 catch 塊</p><p> e1.printStackTrace();</p><p><b> }</b></p><p> comm.sit(this.getName());</p><p> result=comm.qu(this.getName());&l
36、t;/p><p> comm.handle(result, this.getName());</p><p><b> try {</b></p><p> sleep(10);</p><p> } catch (InterruptedException e) {</p><p> //
37、TODO 自動(dòng)生成的 catch 塊</p><p> e.printStackTrace();</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b>
38、 第三個(gè)類(lèi)</b></p><p> package bank1;</p><p> import java.util.Date;</p><p> import java.util.Random;</p><p> import java.util.concurrent.Semaphore;</p>&l
39、t;p> publicclass common {</p><p> privateintzcount;</p><p> privateintaa,bb,cc;</p><p> Semaphore semaphore = new Semaphore(10); </p><p> Semaphore semaphoreq =
40、 new Semaphore(1);</p><p> Semaphore semaphorea = new Semaphore(3);</p><p> Semaphore semaphoreb = new Semaphore(2);</p><p> Semaphore semaphorec = new Semaphore(1);</p>&
41、lt;p> Semaphore semaphorez = new Semaphore(1);</p><p> Random ran1=new Random();</p><p> public common(){</p><p><b> zcount=1;</b></p><p><b>
42、aa=-3;</b></p><p><b> bb=-2;</b></p><p><b> cc=-1;</b></p><p><b> }</b></p><p> publicvoid sit(String name){</p>
43、<p><b> try {</b></p><p> semaphore.acquire();</p><p> } catch (InterruptedException e) {</p><p> // TODO 自動(dòng)生成的 catch 塊</p><p> e.printStackTrace(
44、);</p><p><b> }</b></p><p> Date date=new Date();</p><p> System.out.println("客戶:"+name+"在時(shí)間"+date.toString()+":到達(dá)"+"\n");<
45、/p><p><b> }</b></p><p> public String qu(String name) {</p><p> String a= new String();</p><p><b> try {</b></p><p> semaphoreq.
46、acquire();</p><p> } catch (InterruptedException e) {</p><p> // TODO 自動(dòng)生成的 catch 塊</p><p> e.printStackTrace();</p><p><b> }</b></p><p>&l
47、t;b> intx;</b></p><p><b> inty;</b></p><p> Random ran=new Random();</p><p> x=ran.nextInt(9);</p><p><b> y=zcount;</b></p>
48、<p> //System.out.println(x);</p><p><b> if(x<3){</b></p><p><b> aa++;</b></p><p><b> intaaa;</b></p><p><b> if
49、(aa<0)</b></p><p><b> aaa=0;</b></p><p> else{aaa=aa;}</p><p> a="A"+"--"+y+"該服務(wù)有"+aaa+"人等待";</p><p> S
50、ystem.out.println("客戶:"+name+":取到號(hào):"+a+"\n");</p><p><b> try {</b></p><p> semaphorez.acquire();</p><p> } catch (InterruptedException e
51、) {</p><p> // TODO 自動(dòng)生成的 catch 塊</p><p> e.printStackTrace();</p><p><b> }</b></p><p><b> zcount++;</b></p><p> semaphorez.re
52、lease();</p><p><b> }</b></p><p> elseif(3<=x&&x<=6){</p><p><b> bb++;</b></p><p><b> intbbb;</b></p><p
53、><b> if (bb<0)</b></p><p><b> bbb=0;</b></p><p> else{bbb=bb;}</p><p> a="B"+"--"+y+"該服務(wù)有"+bbb+"人等待";</p
54、><p> System.out.println("客戶:"+name+":取到號(hào):"+a+"\n");</p><p><b> try {</b></p><p> semaphorez.acquire();</p><p> } catch (Inte
55、rruptedException e) {</p><p> // TODO 自動(dòng)生成的 catch 塊</p><p> e.printStackTrace();</p><p><b> }</b></p><p><b> zcount++;</b></p><p&
56、gt; semaphorez.release();</p><p><b> }</b></p><p><b> else{</b></p><p><b> cc++;</b></p><p><b> intccc;</b></p&g
57、t;<p><b> if (cc<0)</b></p><p><b> ccc=0;</b></p><p> else{ccc=cc;}</p><p> a="C"+"--"+y+"該服務(wù)有"+ccc+"人等待&quo
58、t;;</p><p> System.out.println("客戶:"+name+":取到號(hào):"+a+"\n");</p><p><b> try {</b></p><p> semaphorez.acquire();</p><p> } ca
59、tch (InterruptedException e) {</p><p> // TODO 自動(dòng)生成的 catch 塊</p><p> e.printStackTrace();</p><p><b> }</b></p><p><b> zcount++;</b></p>
60、;<p> semaphorez.release();</p><p><b> }</b></p><p> semaphoreq.release();</p><p><b> returna;</b></p><p><b> }</b></
61、p><p> publicvoid handle(String b ,String name){</p><p> if (b.charAt(0)=='A'){</p><p><b> try {</b></p><p> semaphorea.acquire();</p><p
62、> } catch (InterruptedException e) {</p><p> // TODO 自動(dòng)生成的 catch 塊</p><p> e.printStackTrace();</p><p><b> }</b></p><p> semaphore.release();</p&
63、gt;<p> System.out.println(name+":正在對(duì)私服務(wù)窗口辦理業(yè)務(wù)"+"\n");</p><p> intt=(ran1.nextInt(3)+1)*1000;</p><p><b> try {</b></p><p> Thread.sleep(t)
64、;</p><p> } catch (InterruptedException e) {</p><p> // TODO 自動(dòng)生成的 catch 塊</p><p> e.printStackTrace();</p><p><b> }</b></p><p><b>
65、aa--;</b></p><p> semaphorea.release();</p><p> Date date=new Date();</p><p> System.out.println(name+"服務(wù)時(shí)間"+t+"毫秒在"+date+":離開(kāi)"+"\n"
66、);</p><p><b> }</b></p><p> elseif(b.charAt(0)=='B'){</p><p><b> try {</b></p><p> semaphoreb.acquire();</p><p> } cat
67、ch (InterruptedException e) {</p><p> // TODO 自動(dòng)生成的 catch 塊</p><p> e.printStackTrace();</p><p><b> }</b></p><p> semaphore.release();</p><p&
68、gt; System.out.println(name+":正在對(duì)公服務(wù)窗口辦理業(yè)務(wù)"+"\n");</p><p> intt=(ran1.nextInt(3)+1)*1000;</p><p><b> try {</b></p><p> Thread.sleep(t);</p>
69、<p> } catch (InterruptedException e) {</p><p> // TODO 自動(dòng)生成的 catch 塊</p><p> e.printStackTrace();</p><p><b> }</b></p><p><b> bb--;</b
70、></p><p> semaphoreb.release();</p><p> Date date=new Date();</p><p> System.out.println(name+"服務(wù)時(shí)間"+t+"毫秒在"+date+":離開(kāi)"+"\n");</p>
71、;<p><b> }</b></p><p> elseif(b.charAt(0)=='C') {</p><p><b> try {</b></p><p> semaphorec.acquire();</p><p> } catch (Interr
72、uptedException e) {</p><p> // TODO 自動(dòng)生成的 catch 塊</p><p> e.printStackTrace();</p><p><b> }</b></p><p> semaphore.release();</p><p> Syste
73、m.out.println(name+":正在理財(cái)服務(wù)窗口辦理業(yè)務(wù)"+"\n");</p><p> intt=(ran1.nextInt(3)+1)*1000;</p><p><b> try {</b></p><p> Thread.sleep(t);</p><p>
74、; } catch (InterruptedException e) {</p><p> // TODO 自動(dòng)生成的 catch 塊</p><p> e.printStackTrace();</p><p><b> }</b></p><p><b> cc--;</b></p
75、><p> semaphorec.release();</p><p> Date date=new Date();</p><p> System.out.println(name+"服務(wù)時(shí)間"+t+"毫秒在"+date+":離開(kāi)"+"\n");</p><p&g
76、t;<b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> 附件</b></p><p><b> 檢查一</b></p><p>
77、 1信號(hào)量的含義初值?</p><p> zcount座位,初值20。</p><p> qcount取號(hào)機(jī),初值1。</p><p> Counta A類(lèi)窗口,初值3。</p><p> Countb B類(lèi)窗口,初值2。</p><p> Countc C類(lèi)窗口,初值1。</p><p
78、> Countx 計(jì)數(shù)器互斥操作,初值1。</p><p> 2 pv原語(yǔ)對(duì)應(yīng)的api?</p><p><b> Java語(yǔ)言</b></p><p> 信號(hào)量 semaphore</p><p> P :acquire</p><p> V : release</p&
79、gt;<p><b> 線程創(chuàng)建</b></p><p><b> 繼承Thread類(lèi)</b></p><p><b> 實(shí)現(xiàn)run方法</b></p><p> 3 是否要區(qū)分窗口,每一個(gè)窗口都設(shè)置一個(gè)信號(hào)量?</p><p> 不需要,可將每一種窗口
80、化為一類(lèi),判斷有無(wú)空閑即可,有則服務(wù),沒(méi)有則等待。</p><p><b> 檢查二</b></p><p> 1是否設(shè)置服務(wù)時(shí)間,或最大服務(wù)量?</p><p> 根據(jù)作業(yè)要求該功能是可選模塊,可以選擇是否實(shí)現(xiàn),</p><p> 本作業(yè)有實(shí)現(xiàn)可以加一個(gè)if else 判斷是否在服務(wù)時(shí)間段內(nèi),如在則允許創(chuàng)建線程
81、對(duì)象,如不在,則禁止創(chuàng)建,并輸出“不在服務(wù)時(shí)間范圍內(nèi)”。</p><p> 2開(kāi)始客戶到來(lái)的時(shí)間是隨機(jī)的嗎?</p><p> 是,在創(chuàng)建每個(gè)線程之后,調(diào)用start之前產(chǎn)生隨機(jī)數(shù),并且根據(jù)隨機(jī)數(shù)進(jìn)行線程休眠,這樣可以模擬客戶的隨機(jī)到來(lái),但是由于線程運(yùn)行太塊,為了方便展示實(shí)現(xiàn)效果,將休眠的時(shí)間設(shè)置為妙級(jí)的,所以隨機(jī)的到來(lái)時(shí)間只是秒數(shù)或者分鐘不同。</p><p>
溫馨提示
- 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ì)--進(jìn)程通信與進(jìn)程同步機(jī)制實(shí)踐
- 算法課程設(shè)計(jì)---進(jìn)程通信與進(jìn)程同步機(jī)制實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)報(bào)告—多進(jìn)程同步橘子蘋(píng)果問(wèn)題
- 進(jìn)程同步典型例題操作系統(tǒng)
- 操作系統(tǒng)進(jìn)程調(diào)度課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)--進(jìn)程的軟中斷通信與管道通信
- 操作系統(tǒng)進(jìn)程調(diào)度課程設(shè)計(jì)
- 操作系統(tǒng)模擬進(jìn)程課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)---進(jìn)程管理系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)linux系統(tǒng)管理實(shí)踐與進(jìn)程通信實(shí)現(xiàn)
- 進(jìn)程調(diào)度算法 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)進(jìn)程控制課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)---進(jìn)程的創(chuàng)建
- 操作系統(tǒng)進(jìn)程調(diào)度課程設(shè)計(jì)報(bào)告
- 操作系統(tǒng)課程設(shè)計(jì)--進(jìn)程調(diào)度算法
- 操作系統(tǒng)課程設(shè)計(jì)-進(jìn)程調(diào)度模擬
- 操作系統(tǒng)課程設(shè)計(jì)---進(jìn)程調(diào)度算法
- 進(jìn)程調(diào)度算法操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)--進(jìn)程調(diào)度算法
- 進(jìn)程之間的同步互斥與通信理發(fā)師問(wèn)題操作系統(tǒng)課程設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論