版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
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ā)師問題的實(shí)現(xiàn) </p><p> 專業(yè)班級:計(jì)算機(jī)科學(xué)與技術(shù)</p><p> 姓 名: </p><p> 學(xué) 號: </p&
3、gt;<p> 指導(dǎo)教師: </p><p> 成 績: </p><p><b> 摘 要</b></p><p> 理發(fā)師問題是一個利用信號量進(jìn)行PV操作的經(jīng)典問題。設(shè)計(jì)程序?qū)崿F(xiàn)此問題,要使得理發(fā)師的活動與顧客的活動得到各自真實(shí)的模擬。所執(zhí)行的程序
4、應(yīng)體現(xiàn):理發(fā)師在沒有顧客的時候去睡覺,有顧客則工作;顧客在理發(fā)師工作時坐下等待,無座時離開,直至等到理發(fā)師自己理發(fā)。</p><p> 關(guān)鍵字:理發(fā)師,顧客,PV操作。</p><p><b> 目錄</b></p><p><b> 摘 要2</b></p><p><b>
5、 1 設(shè)計(jì)要求4</b></p><p><b> 1.1初始條件4</b></p><p><b> 1.2技術(shù)要求4</b></p><p> 2 總體設(shè)計(jì)思想及開發(fā)環(huán)境與工具4</p><p> 2.1 總體設(shè)計(jì)思想4</p><p>
6、2.2 多線程編程原理5</p><p> 2.2.1 創(chuàng)建一個線程5</p><p> 2.2.2 等待一個線程結(jié)束5</p><p> 2.2.3 信號量6</p><p> 2.3 偽碼實(shí)現(xiàn)6</p><p> 2.4 開發(fā)環(huán)境與工具8</p><p> 3數(shù)據(jù)結(jié)構(gòu)
7、與模塊說明8</p><p> 3.1 數(shù)據(jù)結(jié)構(gòu)8</p><p> 3.2函數(shù)的調(diào)用關(guān)系圖8</p><p> 3.2.1主函數(shù)模塊8</p><p> 3.2.2 理發(fā)師模塊9</p><p> 3.2.3 顧客模塊10</p><p><b> 5運(yùn)行結(jié)果
8、10</b></p><p> 5.1運(yùn)行步驟10</p><p> 5.2測試結(jié)果11</p><p> 5.2.1 編輯,編譯和運(yùn)行的過程圖11</p><p> 5.2.2 錯誤部分截圖12</p><p> 5.2.3 正確運(yùn)行結(jié)果圖12</p><p>
9、;<b> 設(shè)計(jì)總結(jié)16</b></p><p><b> 參考文獻(xiàn)17</b></p><p><b> 致謝18</b></p><p> 附錄(源程序代碼)19</p><p><b> 1 設(shè)計(jì)要求</b></p>
10、<p><b> 1.1初始條件</b></p><p> ?。?)操作系統(tǒng):Linux</p><p> ?。?)程序設(shè)計(jì)語言:C語言</p><p> ?。?)設(shè)有一個理發(fā)師,5把椅子(另外還有一把理發(fā)椅),幾把椅子可用連續(xù)存儲單元。</p><p><b> 1.2技術(shù)要求</b>
11、;</p><p> ?。?)為每個理發(fā)師/顧客產(chǎn)生一個線程,設(shè)計(jì)正確的同步算法</p><p> ?。?)每個顧客進(jìn)入理發(fā)室后,即時顯示“Entered” 及其線程自定義標(biāo)識,還同時顯示理發(fā)室共有幾名顧客及其所坐的位置。</p><p> ?。?)至少有10個顧客,每人理發(fā)至少3秒鐘。</p><p> ?。?)多個顧客須共享操作函數(shù)代碼。
12、</p><p> 2 總體設(shè)計(jì)思想及開發(fā)環(huán)境與工具</p><p> 2.1 總體設(shè)計(jì)思想</p><p> 題目中要求描述理發(fā)師和顧客的行為,因此需要兩類線程barber()和customer ()分別描述理發(fā)師和顧客的行為。其中,理發(fā)師有活動有理發(fā)和睡覺兩個事件;等待和理發(fā)二個事件。店里有固定的椅子數(shù),上面坐著等待的顧客,顧客在到來這個事件時,需判斷有沒
13、有空閑的椅子,理發(fā)師決定要理發(fā)或睡覺時,也要判斷椅子上有沒有顧客。所以,顧客和理發(fā)師之間的關(guān)系表現(xiàn)為:</p><p> ?。?)理發(fā)師和顧客之間同步關(guān)系:當(dāng)理發(fā)師睡覺時顧客近來需要喚醒理發(fā)師為其理發(fā),當(dāng)有顧客時理發(fā)師為其理發(fā),沒有的時候理發(fā)師睡覺。</p><p> ?。?)理發(fā)師和顧客之間互斥關(guān)系:由于每次理發(fā)師只能為一個人理發(fā),且可供等侯的椅子有限只有n把,即理發(fā)師和椅子是臨界資源,
14、所以顧客之間是互斥的關(guān)系。</p><p> ?。?)故引入3個信號量和一個控制變量:</p><p> ?、】刂谱兞縲aiting用來記錄等候理發(fā)的顧客數(shù),初值為0;</p><p> ?、⑿盘柫縞ustomers用來記錄等候理發(fā)的顧客數(shù),并用作阻塞理發(fā)師進(jìn)程,初值為0;</p><p> ?、P盘柫縝arbers用來記錄正在等候顧客的理發(fā)
15、師數(shù),并用作阻塞顧客進(jìn)程,初值為1; ⅳ信號量mutex用于互斥,初值為1 </p><p> 2.2 多線程編程原理</p><p> 此次在Linux下進(jìn)行多線程編程需要用到pthread_create和pthread_join這兩個函數(shù)。</p><p> 2.2.1 創(chuàng)建一個線程</p><p> pthread_create
16、用來創(chuàng)建一個線程,原型為:</p><p> extern int pthread_create((pthread_t *__thread, __const pthread_attr_t *__attr,void *(*__start_routine) (void *), void *__arg))</p><p> 第一個參數(shù)為指向線程標(biāo)識符的指針,第二個參數(shù)用來設(shè)置線程屬性,第三個
17、參數(shù)是線程運(yùn)行函數(shù)的起始地址,最后一個參數(shù)是運(yùn)行函數(shù)的參數(shù)。函數(shù)thread不需要參數(shù)時,最后一個參數(shù)設(shè)為空指針。第二個參數(shù)設(shè)為空指針時,將生成默認(rèn)屬性的線程。創(chuàng)建線程成功后,新創(chuàng)建的線程則運(yùn)行參數(shù)三和參數(shù)四確定的函數(shù),原來的線程則繼續(xù)運(yùn)行下一行代碼。</p><p> 2.2.2 等待一個線程結(jié)束</p><p> pthread_join用來等待一個線程的結(jié)束,函數(shù)原型為:<
18、/p><p> extern int pthread_join __P ((pthread_t __th, void **__thread_return));第一個參數(shù)為被等待的線程標(biāo)識符,第二個參數(shù)為一個用戶定義的指針,它可以用來存</p><p> 儲被等待線程的返回值。這個函數(shù)是一個線程阻塞的函數(shù),調(diào)用它的函數(shù)將一直等待到被</p><p> 等待的線程結(jié)
19、束為止,當(dāng)函數(shù)返回時,被等待線程的資源被收回。</p><p><b> 2.2.3 信號量</b></p><p> ?。?)函數(shù)sem_init()用來初始化一個信號量,函數(shù)原型為: </p><p> extern int sem_init __P ((sem_t *__sem, int __pshared, unsigned int
20、 __value));</p><p> sem為指向信號量結(jié)構(gòu)的一個指針;pshared不為0時此信號量在進(jìn)程間共享,否則只能為當(dāng)前進(jìn)程的所有線程共享;value給出了信號量的初始值。</p><p> ?。?)函數(shù)sem_post( sem_t *sem )用來增加信號量的值。</p><p> 當(dāng)有線程阻塞在這個信號量上時,調(diào)用這個函數(shù)會使其中的一個線程不
21、在阻塞,選擇機(jī)制同樣是由線程的調(diào)度策略決定的。</p><p> ?。?)函數(shù)sem_wait( sem_t *sem )被用來阻塞當(dāng)前線程直到信號量sem的值大于0,解除阻塞后將sem的值減一,表明公共資源經(jīng)使用后減少。函數(shù)sem_trywait ( sem_t *sem )是函數(shù)sem_wait()的非阻塞版本,它直接將信號量sem的值減一。</p><p><b> 2.
22、3 偽碼實(shí)現(xiàn)</b></p><p> difine n 5; //為顧客準(zhǔn)備的椅子數(shù)為5 </p><p> semaphore mutex=1; //用于互斥</p><p> semaphore customers=0;//等候理發(fā)的顧客數(shù)</p><p> semaphore barbers=1;
23、//正在等候顧客的理發(fā)師數(shù)</p><p> int waiting=0; //等候理發(fā)的顧客數(shù) </p><p><b> //理發(fā)師線程</b></p><p> void barber() </p><p><b> {</b></p><p>
24、 while(true) //判斷有無顧客</p><p><b> {</b></p><p> wait(customers); //若無顧客,理發(fā)師睡眠 </p><p> wait(mutex); //互斥 </p><
25、p> waiting--; //等候顧客數(shù)少一個</p><p> signal(mutex); //釋放臨界資源</p><p> signal(barber); //理發(fā)師去為一個顧客理發(fā)</p><p> cut_hair;
26、 //正在理發(fā)</p><p><b> }</b></p><p><b> }</b></p><p><b> //顧客線程</b></p><p> void customer() </p><p><b> {&l
27、t;/b></p><p> wait(mutex); //互斥</p><p> if (waiting<n) //如果有空椅子,則等待</p><p><b> { </b></p><p> waiting++;
28、 //等候顧客數(shù)加1</p><p> signal(mutex); //釋放臨界資源</p><p> signal(customers); //如果理發(fā)師睡覺,喚醒理發(fā)師</p><p> wait(barber); //理發(fā)師在理發(fā), 顧客等候</p><p> get_
29、haircut; //顧客坐下等理發(fā)師 </p><p><b> }</b></p><p><b> else</b></p><p> signal(mutex); //店里人滿了,顧客離開 </p><p><b>
30、}</b></p><p><b> }</b></p><p> 2.4 開發(fā)環(huán)境與工具</p><p> 系統(tǒng)平臺:LINUX環(huán)境</p><p><b> 實(shí)現(xiàn)語言:C語言</b></p><p> 開發(fā)工具:NANO編輯器</p>
31、<p> 3數(shù)據(jù)結(jié)構(gòu)與模塊說明</p><p><b> 3.1 數(shù)據(jù)結(jié)構(gòu)</b></p><p> 通過分析課程設(shè)計(jì)要求,定義以下的數(shù)據(jù):</p><p> sem_t mutex,customers,barbers; //design three semaphores: mutex,customer,barbers<
32、/p><p> int waiting=0; //the number of waiting customers</p><p> int chair[5];</p><p> 3.2函數(shù)的調(diào)用關(guān)系圖</p><p> 3.2.1主函數(shù)模塊</p><p><b> 主函數(shù)流程圖如下:</b&g
33、t;</p><p> 3.2.2 理發(fā)師模塊</p><p> 理發(fā)師模塊函數(shù)流程圖如下:</p><p> 3.2.3 顧客模塊</p><p> 顧客模塊函數(shù)流程圖如下:</p><p><b> 5運(yùn)行結(jié)果</b></p><p><b> 5
34、.1運(yùn)行步驟</b></p><p> (1) 打開桌面上的putty.exe,輸入IP地址192.168.1.254,進(jìn)入開發(fā)環(huán)境。創(chuàng)建一個用來寫程序的文件,這里用的是nano編輯器來編寫c程序。創(chuàng)建SleepingBarber.c的命令為:nano 進(jìn)入編輯環(huán)境,輸入代碼,結(jié)束后按ctrl+x保存為SleepingBarber.c,進(jìn)入文件的命令為:nano SleepingBarber.c,然
35、后可以對其進(jìn)行修改。</p><p> (2) 編譯源程序,編譯命令為:</p><p> cc -lpthread -o SleepingBarber SleepingBarber.c</p><p> (3) 編譯無錯誤后,運(yùn)行程序,命令為:</p><p> ./ SleepingBarber</p>&
36、lt;p><b> 5.2測試結(jié)果</b></p><p> 5.2.1 編輯,編譯和運(yùn)行的過程圖</p><p><b> \</b></p><p> 5.2.2 錯誤部分截圖</p><p> 5.2.3 正確運(yùn)行結(jié)果圖</p><p> 第一次運(yùn)行結(jié)
37、果如下圖:</p><p> 第二次運(yùn)行結(jié)果如下圖:</p><p> 第三次運(yùn)行結(jié)果如下圖;</p><p><b> 設(shè)計(jì)總結(jié)</b></p><p> 兩周的的操作系統(tǒng)課程設(shè)計(jì)終于完成了,回想這兩周的努力,感觸良多。拿到題目時我不知從何下手,想想自己對Liunx一無所知,無奈,只好去查閱相關(guān)書籍,并在網(wǎng)上查
38、找了相關(guān)資料,了解了linux多線程編程的原理,應(yīng)注意的問題,及一些常用命令</p><p> 第一周先設(shè)計(jì)出了該程序的偽代碼即其wait、signal操作。然后,根據(jù)其要求進(jìn)行編程,由于使用的是多線程編程,開始進(jìn)行編譯的時候,編譯命令輸入錯誤,沒有輸入-lpthread,程序總是出現(xiàn)錯誤。同時,創(chuàng)建線程函數(shù)時,由于對其格式輸入錯誤導(dǎo)致程序無法運(yùn)行。例如sb.c,sb1.c等都為本次調(diào)試時的程序。</p&
39、gt;<p> 第二周主要是不斷的調(diào)試并完善程序。程序可以運(yùn)行,但與要求總有些不符,故不斷的進(jìn)行修改,并對其輸出的格式進(jìn)行完善,使其輸出看起來美觀一些,容易觀察一些。例如s.c,b.c等程序?yàn)榇舜握{(diào)試結(jié)果。</p><p> 然后是在原有代碼的基礎(chǔ)上,使程序更完整些。并進(jìn)行結(jié)果的截圖,開始設(shè)計(jì)并編寫課程設(shè)計(jì)說明書。</p><p> 通過本次編程我熟悉了linux 下的
40、多線程編程和信號量實(shí)現(xiàn)wait、signal操作的全過程,對同步和互斥問題也有了更深一步的理解,同時,也使我對linux編程有了更多的了解,在很多方面,它與在windows下編程有著很大的不同,對與多線程來說更方便一些。</p><p> 設(shè)計(jì)過程中也遇到不少困難,尤其是對于多線程的實(shí)現(xiàn),結(jié)果總是不如想象中完美。比如其顧客編號的輸出有時會不按順序,輸入有點(diǎn)亂。另外,有時,輸出結(jié)束后,程序仍無法結(jié)束,必須強(qiáng)制性關(guān)
41、閉終端才可以結(jié)束程序,這是本程序的一個不足之處。</p><p> 在本次課程設(shè)計(jì)中我深深感覺到自己掌握的知識還遠(yuǎn)遠(yuǎn)不夠,我明白光是知道書本上的知識是遠(yuǎn)遠(yuǎn)不夠的,一定要把理論知識和實(shí)踐結(jié)合起來。同時,要多多學(xué)習(xí)linux的操作。</p><p><b> 參考文獻(xiàn)</b></p><p> 1. 湯子瀛,哲鳳屏.《計(jì)算機(jī)操作系統(tǒng)》.西安電
42、子科技大學(xué)學(xué)出版社.</p><p> 2. 王清,李光明.《計(jì)算機(jī)操作系統(tǒng)》.冶金工業(yè)出版社.</p><p> 3.孫鐘秀等. 操作系統(tǒng)教程. 高等教育出版社</p><p> 4.曾明. Linux操作系統(tǒng)應(yīng)用教程. 陜西科學(xué)技術(shù)出版社. </p><p> 5. 張麗芬,劉利雄.《操作系統(tǒng)實(shí)驗(yàn)教程》. 清華大學(xué)出版
43、社.</p><p> 6. 孟靜, 操作系統(tǒng)教程--原理和實(shí)例分析. 高等教育出版社</p><p> 7. 周長林,計(jì)算機(jī)操作系統(tǒng)教程. 高等教育出版社</p><p> 8. 張堯?qū)W,計(jì)算機(jī)操作系統(tǒng)教程,清華大學(xué)出版社</p><p> 9. 任滿杰,操作系統(tǒng)原理實(shí)用教程,電子工業(yè)出版社</p><
44、p><b> 致謝</b></p><p> 在此次課程設(shè)計(jì)的過程中,我首先要感謝我的指導(dǎo)老師xx老師,給了我很大的幫助,與此同時感謝宿舍的舍友,對此次課程設(shè)計(jì)的程序的調(diào)試工作給予了大力的幫助。</p><p><b> 附錄(源程序代碼)</b></p><p> #include<stdio.h&g
45、t;</p><p> #include<stdlib.h></p><p> #include<unistd.h></p><p> #include<pthread.h></p><p> #include<semaphore.h></p><p> #in
46、clude<fcntl.h></p><p> #include<errno.h></p><p> #define n 5 //the shop have five chairs</p><p> //design three semaphores: mutex,customer,barbers</p><p&
47、gt; sem_t mutex,customers,barbers;</p><p> int waiting=0; //the number of waiting customers</p><p> int chair[5]; </p><p> void * barber();</p><p> void * custome
48、r(void *arg);</p><p> int main(int argc,char *argv[])</p><p><b> {</b></p><p> //create 10 semaphores and one Barber semaphore</p><p> pthread_t Custome
49、r_id[10],Barber_id;</p><p><b> int i;</b></p><p> sem_init(&mutex,0,1); //init mutex semaphore to 1</p><p> sem_init(&customers,0,0);//init semaphore custome
50、rs to 0</p><p> sem_init(&barbers,0,1);</p><p> for(i=0;i<5;i++)</p><p> pthread_create(&Barber_id,NULL,(void*)barber,NULL);</p><p> for (i=0;i<10;i++
51、)</p><p> pthread_create(&Customer_id[i],NULL,(void*)customer,(void*)(i+1)); </p><p> for (i=0;i<10;i++)</p><p> pthread_join(Customer_id[i],NULL);</p><p> f
52、or(i=0;i<5;i++)</p><p> pthread_join(Barber_id,NULL);</p><p><b> return 0;</b></p><p><b> }</b></p><p> //creat barber pthread</p>
53、<p> void * barber()</p><p><b> {</b></p><p><b> int i; </b></p><p> int next; </p><p> //wait(customers),if no customers,barber slee
54、ping</p><p> sem_wait(&customers); </p><p> sem_wait(&mutex); //wait(mutex)</p><p> waiting--; //the numer of waiting reduce one</p><p> for(i=0;i<
55、5;i++)</p><p><b> { </b></p><p> if (chair[i]!=0) </p><p><b> { </b></p><p> next= chair[i]; </p><p> chair[i]=0;</p>&
56、lt;p><b> break; </b></p><p><b> } </b></p><p><b> } </b></p><p> printf("The barber is cutting %dth customer's hair\n",next)
57、;</p><p><b> sleep(3);</b></p><p> sem_post(&mutex);</p><p> sem_post(&barbers);</p><p><b> } </b></p><p> //creat cu
58、stomer pthread</p><p> void * customer(void *arg)</p><p><b> {</b></p><p><b> int i;</b></p><p> sem_wait(&mutex); //wait(mutex) if(wai
59、ting<n)</p><p> if(waiting<n)</p><p><b> {</b></p><p> waiting++; //the numer of waiting plus one</p><p> for(i=0;i<5;i++) </p><p&g
60、t;<b> { </b></p><p> if (chair[i]==0) </p><p><b> { </b></p><p> chair[i]=(int)arg; </p><p><b> break;</b></p><p>
61、<b> }</b></p><p><b> }</b></p><p> printf("***************************************************\n"); </p><p> printf("Entered:Number %d cus
62、tomer comes,and sits at %d chair \n",(int)arg,(i+1));</p><p> printf("There are %d customer on the chair\n",waiting); </p><p> printf("The customers' location are:"
63、;); </p><p> for(i=0;i<5;i++) </p><p> printf("%d ",chair[i]); </p><p> printf("\n"); </p><p><b> sleep(1);</b></p><
64、p> sem_post(&mutex); //signal(mutex)</p><p> sem_post(&customers); //signal(customers)</p><p> sem_wait(&barbers); //wait(barbers)</p><p><b> }</b>&l
65、t;/p><p><b> else</b></p><p><b> {</b></p><p> printf("Number %d comes,there are no chairs,the customer %d is leaving\n",(int)arg,(int)arg); </p
溫馨提示
- 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 操作系統(tǒng)課程設(shè)計(jì)理發(fā)師問題說明書
- 課程設(shè)計(jì)--理發(fā)師系統(tǒng)
- 進(jìn)程之間的同步互斥與通信理發(fā)師問題操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)--模擬操作系統(tǒng)的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)——操作系統(tǒng)課程設(shè)計(jì)模擬操作系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)-- 操作系統(tǒng)
- 操作系統(tǒng)課程設(shè)計(jì)---geekos操作系統(tǒng)的研究與實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)-- geekos操作系統(tǒng)的研究與實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)---讀者-寫者問題實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)--蘋果問題
- 理發(fā)師教學(xué)設(shè)計(jì)
- 操作系統(tǒng)程序設(shè)計(jì)課程設(shè)計(jì)報告-操作系統(tǒng)模擬實(shí)現(xiàn)
- 操作系統(tǒng)原理課程設(shè)計(jì)讀者-寫者問題的實(shí)現(xiàn)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)報告--蘋果問題
- 操作系統(tǒng)課程設(shè)計(jì)
- 操作系統(tǒng)課程設(shè)計(jì)
評論
0/150
提交評論