小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

關于Java多線程實現(xiàn)生產者和消費者的問題

 Java修煉館 2011-09-27
在學習Java多線程并發(fā)編程的同時,自己寫了一個用wait()和notifyAll()實現(xiàn)的生產者消費者相互阻塞,保持同步的程序。
設置產品緩沖區(qū)上限為8,可生產者檢查counter計數器等于8的時候wait()并沒有讓多個生產者線程阻塞,而是繼續(xù)向下執(zhí)行,對此表示不解,還請諸位高手們給菜鳥弟弟我一個解答,感激不盡!


Java代碼 復制代碼 收藏代碼
  1. /*  
  2. *   這是一個與多線程有關的以生產者消費者問題為原型的Java程序源碼。  
  3. *   為了體驗notify和notifyAll方法,我嘗試開啟十個生產者和五個消費者線程,對大小為8的緩沖區(qū)進行操作,要做到緩沖區(qū)產品達到8的時候,生產者線程阻塞,直到消費者線程減少緩沖區(qū)的產品數量,并對阻塞進程進行喚醒。  
  4. *   可現(xiàn)在的問題是,當生產者向緩沖區(qū)放入8個產品后,wait()方法并沒有使生產者線程們停住,對此表示很疑惑。  
  5. *  
  6. */  
  7.   
  8.   
  9.   
  10. import java.util.concurrent.ExecutorService;   
  11. import java.util.concurrent.Executors;   
  12.   
  13. class myProducer implements Runnable   
  14. {   
  15.     private myProAndCon mpc;   
  16.        
  17.     myProducer( myProAndCon mpac ){ this.mpc =  mpac; }   
  18.        
  19.     public void run()   
  20.     {   
  21.         try {   
  22.             while(!Thread.interrupted())   
  23.             {      
  24.                     //生產者互斥   
  25.                     synchronized (this){   
  26.   
  27.                         //靜態(tài)計數值達到上限,則wait()阻塞,等待被消費者線程喚醒   
  28.                         while ( mpc.get() >= 8 )   
  29.                            
  30.                         {   
  31.                        
  32.                             System.out.println(mpc.get());   
  33.                                 wait();   
  34.                         }   
  35.                     }   
  36.                        
  37.                     Thread.sleep(100);   
  38.                        
  39.                     //未發(fā)生阻塞時,向緩沖區(qū)內放入產品,增加計數值,并喚醒所有阻塞的消費者線程   
  40.                     synchronized ( mpc.c ){   
  41.                             System.out.println("[ P ] The number is " + mpc.inc() );   
  42.                             mpc.c.notifyAll();   
  43.                     }   
  44.             }   
  45.         } catch (InterruptedException e) {   
  46.             // TODO Auto-generated catch block   
  47.             e.printStackTrace();   
  48.         }   
  49.     }   
  50. }   
  51.   
  52.   
  53. class myConsumer implements Runnable   
  54. {   
  55.     private myProAndCon mpc;   
  56.        
  57.     myConsumer( myProAndCon mpac ){ this.mpc =  mpac; }   
  58.        
  59.     public void run()   
  60.     {      
  61.         try {   
  62.             while(!Thread.interrupted())   
  63.             {   
  64.                 //消費者互斥   
  65.                 synchronized ( this )   
  66.                 {   
  67.                     //當緩沖區(qū)無產品時,消費者線程阻塞,等待被生產者線程喚醒   
  68.                     while ( mpc.get() <= 0 )   
  69.                         wait();   
  70.                 }   
  71.                    
  72.                 Thread.sleep(3000);   
  73.                    
  74.                 //未發(fā)生阻塞時,從緩沖區(qū)取出產品,減少計數值,并喚醒所有阻塞的生產者線程   
  75.                 synchronized (mpc.p){   
  76.                         System.out.println("[ C ] The number is " + mpc.dec() );   
  77.                         mpc.p.notifyAll();   
  78.                 }   
  79.                        
  80.                    
  81.             }   
  82.         } catch (InterruptedException e) {   
  83.             // TODO Auto-generated catch block   
  84.             e.printStackTrace();   
  85.         }   
  86.            
  87.     }   
  88. }   
  89.   
  90.   
  91.   
  92.   
  93. public class myProAndCon {   
  94.     //public final int S = 8;   
  95.   
  96.     //緩沖區(qū)計數器(靜態(tài))以及對其進行的三個synchronized操作   
  97.     volatile private static int  counter = 0;   
  98.        
  99.     synchronized static int inc(){ return ++ counter; }   
  100.     synchronized static int dec(){ return  counter -= 2; }   
  101.     synchronized static int get(){ return  counter; }   
  102.   
  103.     //構造兩個對象,作為開啟線程的參數   
  104.     public myConsumer c = new myConsumer(this);   
  105.     public myProducer p = new myProducer(this);   
  106.        
  107.     private ExecutorService exec = Executors.newCachedThreadPool();   
  108.        
  109.     public myProAndCon(){   
  110.            
  111.         //打開十個生產者線程   
  112.         for ( int i  = 0 ; i < 10 ; i ++ )   
  113.             exec.execute(p);   
  114.            
  115.         //打開五個消費者線程   
  116.         for  ( int i = 0 ; i < 5 ; i ++ )   
  117.             exec.execute(c);   
  118.            
  119.     }   
  120.        
  121.   
  122.     //主函數調用myProAndCon類構造方法,開始執(zhí)行各個線程   
  123.     public static void main(String[] s)   
  124.     {   
  125.         new myProAndCon();   
  126.     }   
  127.        
  128.        

    本站是提供個人知識管理的網絡存儲空間,所有內容均由用戶發(fā)布,不代表本站觀點。請注意甄別內容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多