<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-348  評論-598  文章-0  trackbacks-0

    之前我們已經用常用方法寫了一個消費者與生產者程序,不過看上去有點煩。在JDK 5里面,Java為我們提供了一個可以簡化這方面開發的的接口

    java.util.concurrent.BlockingQueue
    使用BlockingQueue,我們的程序可以這樣寫
    import java.util.concurrent.BlockingQueue;

    public class ConsumerBlockingQueue extends Thread {

        
    private final BlockingQueue<Integer> queue;
        
    private final String name;
        
        
    public ConsumerBlockingQueue(BlockingQueue<Integer> q, String name)
        
    {
            queue
    =q;
            
    this.name=name;
        }

        
    public void run() {
            
    // TODO Auto-generated method stub
            try
            
    {
                
    while(true)
                
    {
                    consume(queue.take());
                    
    try
                    
    {
                        sleep(
    800);// 將消費者的睡眠時間設置得比生產者小是為了演示當產品列表為空的情形
                    }
    catch(Exception e){
                        e.printStackTrace();
                    }

                }

            }
    catch(Exception e){
                e.printStackTrace();
            }

        }

        
        
    private void consume(int i)
        
    {
            System.out.println(name
    +" consume "+i);
        }


    }

    這個是消費者類。
    public class ProducerBlockingQueue extends Thread{
        
        
    private final BlockingQueue<Integer> queue;
        
    private final String name;
        
    private static int i=0;
        
    public ProducerBlockingQueue(BlockingQueue<Integer> q, String name)
        
    {
            queue
    =q;
            
    this.name=name;
        }

        
        
    public void run() {
            
    // TODO Auto-generated method stub
            try
            
    {
                
    while(true)
                
    {
                    queue.add(produce());
                    
    try
                    
    {
                        sleep(
    1000);
                    }
    catch(Exception e){
                        e.printStackTrace();
                    }

                }

                    
            }
    catch(Exception e){
                e.printStackTrace();
            }


        }

        
        
    private int produce()
        
    {
            System.out.println(name
    +" producing "+i);
            
    return i++;
        }


    }

    這個是生產者類。
    import java.util.*;
    import java.util.Collection;
    import java.util.Iterator;
    import java.util.concurrent.BlockingQueue;
    import java.util.concurrent.TimeUnit;

    public class Queue implements BlockingQueue {

        
    private List list=new ArrayList();
        
    public boolean add(Object o) {
            
    // TODO Auto-generated method stub
            list.add(o);
            
    return true;
        }


        
    public Object take() throws InterruptedException {
            
    // TODO Auto-generated method stub
            while(isEmpty()){}
            
    return list.remove(0);
        }



        
    public boolean isEmpty() {
            
    // TODO Auto-generated method stub
            return list.isEmpty();
        }

    // 當然這個類還有其他的方法需要實現,為了清楚起見,我把使用默認實現的方法都去掉了。

    }

    我們定義一個Queue來實現BlockingQueue。下面我們來測試下
    import java.util.concurrent.BlockingQueue;


    public class Test {

        
    /**
         * 
    @param args
         
    */

        
    public static void main(String[] args) {
            
    // TODO Auto-generated method stub
            BlockingQueue<Integer> q=new Queue();
            ProducerBlockingQueue p
    =new ProducerBlockingQueue(q,"p");
            ProducerBlockingQueue p1
    =new ProducerBlockingQueue(q,"p1");
            ConsumerBlockingQueue c
    =new ConsumerBlockingQueue(q,"c");
            ConsumerBlockingQueue c1
    =new ConsumerBlockingQueue(q,"c1");
            p.start();
            p1.start();
            c.start();
            c1.start();
        }


    }

    看到沒有,就這么簡單,以很少的邏輯代碼實現了消費者與生產者功能,當然你還可以對他進行擴充,讓他更加完善。


    ---------------------------------------------------------
    專注移動開發

    Android, Windows Mobile, iPhone, J2ME, BlackBerry, Symbian
    posted on 2007-04-28 12:11 TiGERTiAN 閱讀(2411) 評論(4)  編輯  收藏 所屬分類: Java

    評論:
    # re: 使用BlockingQueue來簡化消費者與生產者的問題 2007-04-28 14:18 | 王凌華
    Java文檔里面也有個類似的玩意,

    -----------------------------------------------------------------
    class Producer implements Runnable {
    private final BlockingQueue queue;
    Producer(BlockingQueue q) { queue = q; }
    public void run() {
    try {
    while (true) { queue.put(produce()); }
    } catch (InterruptedException ex) { ... handle ...}
    }
    Object produce() { ... }
    }

    class Consumer implements Runnable {
    private final BlockingQueue queue;
    Consumer(BlockingQueue q) { queue = q; }
    public void run() {
    try {
    while (true) { consume(queue.take()); }
    } catch (InterruptedException ex) { ... handle ...}
    }
    void consume(Object x) { ... }
    }

    class Setup {
    void main() {
    BlockingQueue q = new SomeQueueImplementation();
    Producer p = new Producer(q);
    Consumer c1 = new Consumer(q);
    Consumer c2 = new Consumer(q);
    new Thread(p).start();
    new Thread(c1).start();
    new Thread(c2).start();
    }
    }

    你不是抄襲的吧。:)   回復  更多評論
      
    # re: 使用BlockingQueue來簡化消費者與生產者的問題 2007-04-28 14:28 | TiGERTiAN
    哈哈。。抄襲抄襲。文檔上面的不詳細,寫個能運行得出來。。當作學習。。  回復  更多評論
      
    # re: 使用BlockingQueue來簡化消費者與生產者的問題 2008-12-01 15:47 | qw
    public Object take() throws InterruptedException {
    // TODO Auto-generated method stub
    while(isEmpty()){}
    return list.remove(0);
    }

    while(isEmpty()){},這個代碼你也敢寫?  回復  更多評論
      
    # re: 使用BlockingQueue來簡化消費者與生產者的問題 2008-12-01 15:58 | TiGERTiAN
    @qw
    怎么了?是一個無限循環,主要是有一個生產線程在那里,我才這樣寫的,如果是實際開發當然要做相應處理,不能這樣寫了。  回復  更多評論
      
    主站蜘蛛池模板: 亚洲成AV人片在线观看无码| 91香蕉成人免费网站| 一区免费在线观看| 国产亚洲精品国产福利在线观看| 精品国产日韩亚洲一区91| 亚洲av无码专区亚洲av不卡| 亚洲老熟女五十路老熟女bbw| 亚洲av无码专区国产不乱码| 亚洲爆乳无码专区www| 国产精品亚洲专区无码WEB| 精品国产亚洲AV麻豆| 亚洲av无码偷拍在线观看| 校园亚洲春色另类小说合集| 美女隐私免费视频看| 亚洲高清免费视频| 很黄很污的网站免费| 久久精品无码专区免费青青| 久久久久av无码免费网| 最近中文字幕免费mv视频7| 日本高清色本免费现在观看| www.亚洲精品| 好看的亚洲黄色经典| 亚洲黄色在线观看| 亚洲综合色一区二区三区| 老司机午夜免费视频| 中文字幕av无码不卡免费| 中文字幕亚洲免费无线观看日本| 麻豆最新国产剧情AV原创免费| 日韩精品无码人妻免费视频| 亚洲中文字幕视频国产| 亚洲av福利无码无一区二区| 亚洲国产成人精品久久| 国产成人亚洲精品无码AV大片| 中文字幕手机在线免费看电影| 84pao国产成视频免费播放| 成人免费在线视频| 久久久久亚洲?V成人无码| 亚洲一级二级三级不卡| 久久水蜜桃亚洲AV无码精品| 91在线免费视频| 久久久久久国产a免费观看黄色大片 |