版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> *******************</p><p><b> 實(shí)踐教學(xué)</b></p><p> *******************</p><p><b> 計(jì)算機(jī)與通信學(xué)院</b></p><p><b> 2011年秋季學(xué)期</b>&
2、lt;/p><p><b> 操作系統(tǒng) 課程設(shè)計(jì)</b></p><p> 題 目: 理發(fā)師問題 </p><p> 專業(yè)班級(jí): 軟件一班 </p><p> 姓 名: </p><p> 學(xué) 號(hào): </p>
3、<p> 指導(dǎo)教師: </p><p> 成 績:_______________</p><p><b> 目 錄</b></p><p> 目 錄············&
4、#183;····································
5、;·········2</p><p> 摘 要······················
6、83;···································3</p
7、><p> 關(guān) 鍵 字·································
8、·························3</p><p> 設(shè)計(jì)思想·······
9、····································
10、3;··············4</p><p> 正 文·················
11、183;····································
12、····4</p><p> 一、數(shù)據(jù)結(jié)構(gòu)···························
13、3;·······················5</p><p> 1、信號(hào)量········
14、83;····································&
15、#183;····5</p><p> 2、全局變量···························
16、;·····················5</p><p> 3、函數(shù)···········
17、;····································
18、83;····5</p><p> 二、程序模塊···························&
19、#183;·······················6</p><p> 理發(fā)師模塊流程圖·······
20、83;······························6</p><p> 顧客模塊流程圖·
21、····································
22、3;···7</p><p> 主程序流程圖····························
23、183;··············8</p><p> PV操作偽代碼·················
24、;·························9</p><p> 三、運(yùn)行結(jié)果······
25、83;····································&
26、#183;······10</p><p> 代碼編輯·························
27、······················10</p><p> 編譯運(yùn)行··········
28、;····································
29、83;12</p><p> 運(yùn)行結(jié)果·······························
30、183;···············12</p><p> 設(shè)計(jì)總結(jié)················&
31、#183;····································
32、;····13參考文獻(xiàn)· 致謝······························
33、···················14附錄:源代碼················
34、183;····································
35、15</p><p><b> 摘 要</b></p><p> 理發(fā)師問題是一個(gè)利用信號(hào)量進(jìn)行PV操作的經(jīng)典問題。設(shè)計(jì)程序?qū)崿F(xiàn)此問題,要使得理發(fā)師的活動(dòng)與顧客的活動(dòng)得到各自真實(shí)的模擬。所執(zhí)行的程序應(yīng)體現(xiàn):理發(fā)師在沒有顧客的時(shí)候去睡覺,有顧客則工作;顧客在理發(fā)師工作時(shí)坐下等待,無座時(shí)離開,直至等到理發(fā)師自己理發(fā)。</p><p> 關(guān)鍵
36、字:理發(fā)師,顧客,PV操作。</p><p><b> 設(shè)計(jì)思想</b></p><p> 打瞌睡的理發(fā)師問題是一種同步問題的抽象描述。計(jì)算機(jī)系統(tǒng)中的每個(gè)進(jìn)程都可以消費(fèi)或生產(chǎn)某類資源,當(dāng)系統(tǒng)中某一進(jìn)程使用某一資源時(shí),可以看作是消耗,且該進(jìn)程稱為消費(fèi)者。而當(dāng)某個(gè)進(jìn)程釋放資源時(shí),則它就相當(dāng)一個(gè)生產(chǎn)者。因此此題可看作是n個(gè)生產(chǎn)者和1個(gè)消費(fèi)者問題。顧客作為生產(chǎn)者,每到來一
37、個(gè)就使計(jì)數(shù)器count增加1,以便讓理發(fā)師理發(fā)(相當(dāng)于消費(fèi))至最后一個(gè)顧客(相當(dāng)于產(chǎn)品)。并且,第1個(gè)到來的顧客應(yīng)負(fù)責(zé)喚醒理發(fā)師;如果不是第1個(gè)到達(dá)的顧客,則在有空椅子的情況下坐下等待,否則離開理發(fā)店(該消息可由計(jì)數(shù)器count獲得)。所以可以通過一個(gè)有界緩沖區(qū)把理發(fā)師和顧客聯(lián)系起來。而其中的信號(hào)也具有兩種功能:一是跟蹤資源的理發(fā)師和顧客的計(jì)數(shù)器;二是協(xié)調(diào)資源的理發(fā)師和顧客之間的同步器。通過對(duì)信號(hào)進(jìn)行P、V操作來實(shí)現(xiàn)有關(guān)問題和相關(guān)描述。
38、</p><p><b> 數(shù)據(jù)結(jié)構(gòu):</b></p><p> 1、信號(hào)量:int Custom;//所有到達(dá)的顧客,包括正在被理發(fā)的顧客,所以一般情況下,Custom比Wait_Person大1</p><p> int Mutex;//用于實(shí)現(xiàn)全局變量Wait——preson訪問的互斥</p>&l
39、t;p> int Wait_Leave;//等待離開信號(hào)量,用來表示幾個(gè)顧客等待離開,只要理發(fā)師為其理發(fā)完畢,他就可以離開了</p><p> 全局變量:int * Is_Sleeping;//當(dāng)前理發(fā)師是否在睡覺</p><p> 3、函數(shù): void print1(int Wait_person)</p><p> void print2(i
40、nt ID)</p><p> 4:Linux 提供的多線程函數(shù):</p><p> int pthread_create(pthread_t *—thread,_const pthread_attr_t *attr,void*(*start_rtn)(void*),void *arg);</p><p> int pthread_join __P ((
41、pthread_t __th, void **__thread_return));pthread_attr_init(&attr);</p><p> pthread_attr_getschedparam(&attr, ¶m);</p><p> param.sched_priority=newprio;</p><p
42、> pthread_attr_setschedparam(&attr, ¶m);</p><p> pthread_create(&tid, &attr, (void *)myfunction, myarg);</p><p> pthread_detach(thread_id);pthread_t pthread_self(void);
43、</p><p><b> 二、程序模塊:</b></p><p> 1、理發(fā)師模塊流程圖:</p><p><b> 顧客模塊流程圖:</b></p><p><b> 3、主程序流程圖:</b></p><p><b> 4、PV
44、操作偽代碼</b></p><p> int waiting=0 ; //等候理發(fā)的顧客數(shù) </p><p> int chairs=n; //為顧客準(zhǔn)備的椅子數(shù) </p><p> semaphore customers=0, barbers=0,mutex=1; </p><p><b> barber()
45、</b></p><p><b> { </b></p><p> while(TRUE); //理完一人,還有顧客嗎? </p><p> P(cutomers); //若無顧客,理發(fā)師睡眠 </p><p> P(mutex); //進(jìn)程互斥 </p><p> wait
46、ing -= 1;//等候顧客數(shù)少一個(gè) </p><p> V(barbers); //理發(fā)師去為一個(gè)顧客理發(fā) </p><p> V(mutex); //開放臨界區(qū) </p><p> cut-hair( ); //正在理發(fā)</p><p><b> } </b></p><p> c
47、ustomer() </p><p><b> { </b></p><p> P(mutex); //進(jìn)程互斥 </p><p> if (waiting) </p><p><b> { </b></p><p> waiting += 1; // 等候顧客數(shù)加
48、1</p><p> V(customers); //必要的話喚醒理發(fā)師 </p><p> V(mutex); //開放臨界區(qū) </p><p> P(barbers); //無理發(fā)師, 顧客坐著養(yǎng)神 </p><p> get-haircut( ); //一個(gè)顧客坐下等理/</p><p><b>
49、; } </b></p><p> else V(mutex); //人滿了,離開</p><p><b> }</b></p><p><b> 三、測(cè)試結(jié)果:</b></p><p><b> 代碼編輯:</b></p><p>
50、;<b> 2、編譯運(yùn)行:</b></p><p><b> 3、運(yùn)行結(jié)果:</b></p><p><b> 設(shè)計(jì)總結(jié)</b></p><p> 本次課程設(shè)計(jì)完成了多進(jìn)程同步方法理發(fā)師問題全部過程,結(jié)果滿足設(shè)計(jì)要求,驗(yàn)證無誤。設(shè)計(jì)過程中也遇到不少困難,尤其是關(guān)于多進(jìn)程程序的設(shè)計(jì)實(shí)現(xiàn)。特別需要
51、注意的是由于進(jìn)程的數(shù)據(jù)共享會(huì)帶來其他一些問題,while循環(huán)中的各個(gè)循環(huán)小模塊需要嚴(yán)格區(qū)別開來,才能使輸出結(jié)果正確有序。這些正是編寫多進(jìn)程程序時(shí)最需要注意的地方。</p><p> 通過本次設(shè)計(jì),我較好地掌握了通過研究Linux 的進(jìn)程機(jī)制和信號(hào)量實(shí)現(xiàn)PV操作的全過程,尤其是對(duì)多進(jìn)程程序設(shè)計(jì)方法有了更深的理解,開拓了思路,鍛煉了實(shí)踐動(dòng)手能手,達(dá)到了課程設(shè)計(jì)目的。</p><p><
52、b> 參考文獻(xiàn)·致謝</b></p><p> 1. 湯子瀛,哲鳳屏.《計(jì)算機(jī)操作系統(tǒng)》.西安電子科技大學(xué)學(xué)出版社.</p><p> 2. 王清,李光明.《計(jì)算機(jī)操作系統(tǒng)》.冶金工業(yè)出版社.</p><p> 3.孫鐘秀等. 操作系統(tǒng)教程. 高等教育出版社</p><p> 4.曾明. Li
53、nux操作系統(tǒng)應(yīng)用教程. 陜西科學(xué)技術(shù)出版社. </p><p> 5. 張麗芬,劉利雄.《操作系統(tǒng)實(shí)驗(yàn)教程》. 清華大學(xué)出版社.</p><p> 6. 孟靜, 操作系統(tǒng)教程--原理和實(shí)例分析. 高等教育出版社</p><p> 7. 周長林,計(jì)算機(jī)操作系統(tǒng)教程. 高等教育出版社</p><p> 8. 張堯?qū)W,計(jì)算機(jī)操作
54、系統(tǒng)教程,清華大學(xué)出版社</p><p> 9. 任滿杰,操作系統(tǒng)原理實(shí)用教程,電子工業(yè)出版社</p><p> 在此次課程設(shè)計(jì)的過程中,我首先要感謝我的指導(dǎo)老師王旭陽老師,給了我很大的幫助,與此同時(shí)感謝宿舍的舍友,對(duì)此次課程設(shè)計(jì)的程序的調(diào)試工作給予了大力的幫助。</p><p><b> 附錄:源代碼</b></p>&l
55、t;p> #include <sys/mman.h></p><p> #include <sys/types.h></p><p> #include <linux/sem.h></p><p> #include <fcntl.h></p><p> #include <
56、;unistd.h></p><p> #include <stdio.h></p><p> #include <errno.h></p><p> #include <time.h></p><p> #define N 5 </p><p> #defi
57、ne M 20 </p><p> int Custom;</p><p> int Mutex;</p><p> int Wait_Leave;</p><p> int * Is_Sleeping;</p><p> void print1(int Wait_person)</p>&
58、lt;p><b> {</b></p><p> if(!Wait_person)</p><p><b> {</b></p><p> printf("No customer here, go to sleep.\n");</p><p> *Is_Sleep
59、ing=1;</p><p><b> }</b></p><p><b> }</b></p><p> void print2(int ID)</p><p><b> {</b></p><p> if(*Is_Sleeping)<
60、/p><p><b> {</b></p><p> printf("New customer %d comes, weak up the barber.\n",ID);</p><p> *Is_Sleeping=0;</p><p><b> }</b></p>
61、;<p><b> else</b></p><p> printf("New customer %d comes, there are somes chairs free , sits and waites.\n",ID);</p><p><b> }</b></p><p>
62、 int main()</p><p><b> {</b></p><p> struct sembuf P,V;</p><p> union semun arg;</p><p> int Pid,i=0;</p><p> int * Wait_Person;</p>
63、<p> //映射共享內(nèi)存,臨界區(qū)</p><p> Wait_Person=(int * )mmap(NULL,sizeof(int),PROT_READ|PROT_WRITE,MAP_SHARED|MAP_ANONYMOUS,-1,0);</p><p> *Wait_Person=0;</p><p> Is_Sleeping=(int
64、* )mmap(NULL,sizeof(int),PROT_READ|PROT_WRITE,MAP_SHARED|MAP_ANONYMOUS,-1,0);</p><p> *Is_Sleeping=0;</p><p> Custom=semget(IPC_PRIVATE,1,IPC_CREAT|00666);</p><p> Mutex=semget(I
65、PC_PRIVATE,1,IPC_CREAT|00666);</p><p> Wait_Leave=semget(IPC_PRIVATE,1,IPC_CREAT|00666);</p><p> arg.val = 0;</p><p> if(semctl(Custom,0,SETVAL,arg)==-1)</p><p> pe
66、rror("semctl semeval error");</p><p> arg.val = 1;</p><p> if(semctl(Mutex,0,SETVAL,arg)==-1)</p><p> perror("semctl semeval error");</p><p> ar
67、g.val = 0;</p><p> if(semctl(Wait_Leave,0,SETVAL,arg)==-1)</p><p> perror("semctl semeval error");</p><p> V.sem_num=0;</p><p> V.sem_op=1;</p><
68、;p> V.sem_flg=SEM_UNDO;</p><p> P.sem_num=0;</p><p> P.sem_op=-1;</p><p> P.sem_flg=SEM_UNDO;</p><p> Pid=fork();</p><p> if(Pid==0)</p>&l
69、t;p><b> {//理發(fā)師進(jìn)程</b></p><p><b> while(1)</b></p><p><b> {</b></p><p> semop(Mutex,&P,1);</p><p> print1(*Wait_Person);&l
70、t;/p><p> semop(Mutex,&V,1);</p><p> semop(Custom,&P,1);</p><p> semop(Mutex,&P,1);</p><p> (*Wait_Person)--;</p><p> semop(Mutex,&V,1);&
71、lt;/p><p> printf("Barber is working!\n");</p><p><b> sleep(3);</b></p><p> printf("One job finished.\n");</p><p> semop(Wait_Leave,&am
72、p;V,1);</p><p><b> }</b></p><p> printf("******************Last one is finished, close the dodr.**********************\n");</p><p><b> }</b><
73、/p><p><b> else</b></p><p><b> {</b></p><p><b> while(1)</b></p><p><b> {</b></p><p> if(Pid==0)</p>
74、;<p><b> {</b></p><p> semop(Mutex,&P,1);</p><p> if((*Wait_Person)>=N)</p><p><b> {</b></p><p> semop(Mutex,&V,1);</p
75、><p> printf("New customer %d comes,there is no chair and go away.\n",getpid());</p><p><b> exit(0);</b></p><p><b> }</b></p><p><b
76、> else</b></p><p><b> {</b></p><p> print2(getpid());喚醒理發(fā)師,否則,等待</p><p> (*Wait_Person)++;</p><p> semop(Mutex,&V,1);</p><p>
77、 semop(Custom,&V,1);</p><p> semop(Wait_Leave,&P,1);</p><p> printf("Customer %d finished,get out of here.\n",getpid());</p><p><b> exit(0);</b><
78、;/p><p><b> }</b></p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> sleep(rand()%100/30.0);&l
79、t;/p><p><b> if(i<M)</b></p><p><b> {</b></p><p> Pid=fork();</p><p><b> i++;</b></p><p><b> }</b><
80、/p><p><b> else</b></p><p><b> break;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> if(i==M)<
81、/b></p><p><b> {</b></p><p> wait(NULL);</p><p><b> }</b></p><p><b> }</b></p><p><b> return 0;</b>
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲(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ì)---理發(fā)師問題的實(shí)現(xiàn)
- 課程設(shè)計(jì)--理發(fā)師系統(tǒng)
- 進(jìn)程之間的同步互斥與通信理發(fā)師問題操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)說明書(樣板)
- 操作系統(tǒng)課程設(shè)計(jì)——操作系統(tǒng)課程設(shè)計(jì)模擬操作系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)-- 操作系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)說明
- 操作系統(tǒng)課程設(shè)計(jì)--蘋果問題
- 理發(fā)師教學(xué)設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)報(bào)告--蘋果問題
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 理發(fā)師悖論
- 理發(fā)師教學(xué)設(shè)計(jì)61304
- 理發(fā)師教學(xué)設(shè)計(jì)61236
- 操作系統(tǒng)課程設(shè)計(jì)指導(dǎo)書
評(píng)論
0/150
提交評(píng)論