操作系統(tǒng)課程設(shè)計(jì)--進(jìn)程通信與進(jìn)程同步機(jī)制實(shí)踐_第1頁(yè)
已閱讀1頁(yè),還剩14頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論