操作系統(tǒng)課程設(shè)計——司機與售票員_第1頁
已閱讀1頁,還剩11頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  《操作系統(tǒng)》</b></p><p>  題 目: 司機與售票員 </p><p>  班 級: </p><p>  學(xué) 號: </p><p>  

2、作者姓名: </p><p>  指導(dǎo)教師: </p><p>  2013年12月28日</p><p>  目 錄</p><p><b>  一、設(shè)計思想1</b></p><p><b&

3、gt;  1.1設(shè)計目的1</b></p><p><b>  1.2需求分析1</b></p><p><b>  二、概要設(shè)計1</b></p><p>  2.1 設(shè)計內(nèi)容1</p><p>  2.2 數(shù)據(jù)結(jié)構(gòu)及模塊說明2</p><p>  2

4、.3開發(fā)環(huán)境與工具2</p><p><b>  三、程序代碼3</b></p><p><b>  四、運行結(jié)果9</b></p><p><b>  五、心得體會10</b></p><p><b>  六、參考文獻10</b></p&

5、gt;<p><b>  一、設(shè)計思想</b></p><p><b>  1.1設(shè)計目的</b></p><p>  掌握信號的使用方法和PV 操作的定義,掌握使用PV 操作實現(xiàn)進程之間同步和互斥的方法,加深對進程同步互斥概念的理解。</p><p><b>  1.2需求分析</b>

6、</p><p>  本程序的功能是模擬公車的司機和售票員的開門以及行車的過程,其實也就是一個典型的進程同步互斥問題,其中主要的兩點是</p><p>  1、司機開車的時候,售票員不能開門,(這里體現(xiàn)的是進程的互斥問題)車停之后,由司機通知售票員開門(這里體現(xiàn)的是進程的同步問題);</p><p>  2、車門開著的時候,司機不能開車,等售票員把車門關(guān)上之后,由售

7、票員通知司機開車。</p><p><b>  二、概要設(shè)計</b></p><p><b>  2.1設(shè)計內(nèi)容</b></p><p>  創(chuàng)建兩個進程模擬售票員和汽車司機的同步行為,具體設(shè)計內(nèi)容:司機的活動:啟動車輛,正常行車,到站停車。售票員活動:關(guān)車門,售票,開車門。當(dāng)發(fā)車時間到,售票員關(guān)好車門后,司機才能啟動車輛

8、,售票員才開始售票。當(dāng)?shù)秸緯r,司機停穩(wěn)車后,售票員才能打開車門,車上乘客先下車,然后站牌乘客上車。</p><p>  司機與售票員要協(xié)同工作:一方面只有售票員把門關(guān)好之后司機才可開車,因此售票員關(guān)好門之后要通知司機開車,然后售票;另一方面,也只有司機把車停下之后售票員才能開門讓乘客下車和上車,因此,此時司機應(yīng)通知售票員。汽車當(dāng)前正在始發(fā)站停車讓乘客讓乘客上車,因此,必須設(shè)置一定的信號量來實現(xiàn)他們之間的同步問題。

9、</p><p>  2.2數(shù)據(jù)結(jié)構(gòu)及模塊說明</p><p>  本程序的設(shè)計原理比較簡單,就是兩大部分,一是司機的行車操作過程,另一個是售票員的開車門和關(guān)車門(以及售票,本程序不討論售票過程)的過程。</p><p>  把司機與售票員的信號量設(shè)置為全局變量,并把客車上的人數(shù):現(xiàn)在人數(shù)、下車人數(shù)、上車人數(shù)設(shè)置為全局變量;設(shè)置司機與售票員各自的線程。考慮到第一站和

10、最后一站的問題,應(yīng)單獨處理,故在各自的線程中分情況討論:</p><p>  由于下車的人數(shù)是隨機的,設(shè)計時考慮到了人數(shù)可能會超過客車的最大上限的問題。具體的思路是下面的圖示。</p><p> ?。╝)司機的工作流程 (b)售票員的工作流程</p><p>  2.3開發(fā)環(huán)境與工具</p><p>  系統(tǒng)平臺:Windows

11、7</p><p><b>  實現(xiàn)語言:C++</b></p><p>  開發(fā)工具:VC++6.0</p><p><b>  三、程序代碼</b></p><p>  #include<stdlib.h></p><p>  #include<stdi

12、o.h></p><p>  #include<windows.h></p><p>  #include<time.h></p><p>  #define Total_num 50 //客車的最大容量 </p><p>  #define Total_stop 4 //總的站數(shù) <

13、;/p><p><b>  //全局變量 </b></p><p>  int Recent_num=0; //某一時刻的客車上的人數(shù) </p><p>  int Get_on_num; //上車的人數(shù) </p><p>  int Get_off_num; //

14、下車的人數(shù) </p><p>  int stop=1; //客車到達路線的站數(shù) </p><p>  HANDLE Semaphore_driver; //Driver的信號量 </p><p>  HANDLE Semaphore_conductor;//Conductor的信號量 </p><p>  

15、//產(chǎn)生一定范圍的隨機數(shù),可避免下面程序的判斷是否超出客車的最大容量問題 </p><p>  int Get_random(int min,int max)</p><p><b>  {</b></p><p><b>  int a;</b></p><p>  srand((int)time

16、(0));</p><p><b>  while(1)</b></p><p><b>  {</b></p><p>  a=rand()%(Total_num+1);</p><p>  if(a>=min && a<=max)</p><p&g

17、t;<b>  return a;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  //Driver的線程 </p><p>  DWORD WINAPI Thread_Driver(LPVOID Driver) &l

18、t;/p><p><b>  {</b></p><p>  while(stop<=Total_num)</p><p><b>  {</b></p><p>  if(stop==Total_stop)</p><p><b>  {</b>&l

19、t;/p><p>  WaitForSingleObject(Semaphore_driver,INFINITE);</p><p>  printf("終點站到了\n");</p><p>  printf("最后乘客:%d名\n",Recent_num); </p><p>  ReleaseSemap

20、hore(Semaphore_conductor,1,NULL);</p><p>  return 0; </p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>

21、;  if(stop==1) printf("第%d站出發(fā)\n啟動車輛\n",stop);</p><p>  else printf("第%d站到了\n",stop);</p><p>  if(stop!=1) printf("到站停車\n");</p><p>  ReleaseSemaphore(S

22、emaphore_conductor,1,NULL);// 增加信號量</p><p>  WaitForSingleObject(Semaphore_driver,INFINITE);</p><p>  printf("正常行車\n");</p><p>  ReleaseSemaphore(Semaphore_conductor,1,NUL

23、L);</p><p><b>  }</b></p><p>  Sleep(1000);</p><p><b>  }</b></p><p><b>  return 0;</b></p><p><b>  } </b>

24、;</p><p>  //Conductor的線程 </p><p>  DWORD WINAPI Thread_Conductor(LPVOID Conductor) </p><p><b>  {</b></p><p><b>  while(1)</b></p><

25、;p><b>  {</b></p><p>  if(stop<Total_stop)</p><p><b>  {</b></p><p>  WaitForSingleObject(Semaphore_conductor,INFINITE);</p><p>  if(stop=

26、=1)</p><p><b>  {</b></p><p>  Get_on_num=Get_random(0,Total_num-Recent_num);</p><p>  printf("有%d名乘客上車\n",Get_on_num); </p><p>  Recent_num+=Get_

27、on_num; </p><p><b>  } </b></p><p><b>  else </b></p><p><b>  {</b></p><p>  printf("開車門\n");</p><p>  Ge

28、t_off_num=Get_random(0,Recent_num);</p><p>  printf("有%d名乘客下車\n",Get_off_num,stop);</p><p>  Sleep(1000);//避免了時間的問題帶來的不是隨機數(shù)的現(xiàn)象 </p><p>  Recent_num-=Get_off_num;</p>

29、<p>  Get_on_num=Get_random(0,Total_num-Recent_num);</p><p>  printf("有%d名乘客上車\n",Get_on_num,stop); </p><p>  Recent_num+=Get_on_num;</p><p><b>  }</b>&

30、lt;/p><p>  printf("此時乘客:%d名\n",Recent_num); </p><p>  printf("關(guān)車門\n");</p><p>  ReleaseSemaphore(Semaphore_driver,1,NULL);</p><p>  WaitForSingleObjec

31、t(Semaphore_conductor,INFINITE);</p><p>  printf("售票\n"); </p><p>  printf("\n\n\n\n");</p><p><b>  stop++;</b></p><p><b>  }</

32、b></p><p>  if(stop==Total_stop){</p><p>  ReleaseSemaphore(Semaphore_driver,1,NULL);</p><p>  WaitForSingleObject(Semaphore_conductor,INFINITE);</p><p>  printf(&qu

33、ot;開車門\n");</p><p>  printf("所有乘客下車\n");</p><p><b>  return 0;</b></p><p><b>  } </b></p><p>  Sleep(1000); </p><p&

34、gt;<b>  }</b></p><p><b>  return 0;</b></p><p><b>  }</b></p><p>  //主函數(shù) </p><p>  int main()</p><p><b>  {&l

35、t;/b></p><p>  HANDLE Driver;</p><p>  HANDLE Conductor; </p><p>  Semaphore_driver=CreateSemaphore(NULL,0,1,"semaphore_driver"); //創(chuàng)建Driver的信號量 </p>&l

36、t;p>  Semaphore_conductor=CreateSemaphore(NULL,0,1,"semaphore_conductor");//創(chuàng)建Conductor的信號量 </p><p>  Driver=CreateThread(NULL,0,Thread_Driver,&Driver,0,NULL); //創(chuàng)建Driver的線程</p&

37、gt;<p>  Conductor=CreateThread(NULL,0,Thread_Conductor,&Conductor,0,NULL); //創(chuàng)建Conductor的線程 </p><p>  CloseHandle(Driver); //關(guān)閉Driver的線程 </p><

38、;p>  CloseHandle(Conductor);//關(guān)閉Conductor的線程 </p><p>  //GetLastError();</p><p><b>  while(1);</b></p><p>  system("pause");</p><p><b>  

39、return 0;</b></p><p><b>  }</b></p><p><b>  四、運行結(jié)果</b></p><p><b>  五、心得體會</b></p><p>  1、因為司機與售票員是兩條單獨處理的線程。程序先對司機的線程進行設(shè)計,接著再進

40、行售票員的線程設(shè)計。因為兩者是需要相互協(xié)調(diào),又先后順序的,所以編起程序來比較復(fù)雜,而且很亂,尤其對于第一次接觸的我們而言。</p><p>  2、上下車的人數(shù)是隨機的,所以要使程序能夠判斷所出現(xiàn)的隨機數(shù)在汽車可以承載的最大容量之內(nèi)。</p><p>  3、C++語言基礎(chǔ)不是很好,所以編起程序來比較費力,這種設(shè)計性的實驗對于我們而言還是有一定的難度的,所以部分程序是參照網(wǎng)上的類似程序。&

41、lt;/p><p><b>  六、參考文獻</b></p><p>  《計算機操作系統(tǒng)》 西安電子科技大學(xué)出版社 </p><p>  《操作系統(tǒng)實驗教程》清華大學(xué)出版社</p><p>  《操作系統(tǒng)原理與實踐教程》清華大學(xué)出版社</p><p>  《Windows 操作系統(tǒng)核心編程實驗教程》

溫馨提示

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

評論

0/150

提交評論