<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无码兔费综合| 免费污视频在线观看| 久久久久亚洲精品无码网址| 在线观看免费黄色网址| 亚洲春色另类小说| 国产一级淫片a视频免费观看| baoyu122.永久免费视频| 亚洲一区中文字幕| 亚洲欧洲精品无码AV| 在线观看H网址免费入口| 丰满妇女做a级毛片免费观看| 久久久久久亚洲精品成人| 亚洲第一区在线观看| 中文字幕免费在线| 成人免费观看男女羞羞视频| 亚洲欧洲在线播放| 亚洲中文字幕视频国产| 国产免费看JIZZ视频| 99re6在线视频精品免费| 中文字幕在线观看亚洲日韩| 亚洲精品高清国产一线久久| 日本免费v片一二三区| 全部免费毛片在线播放| 一进一出60分钟免费视频| 中文字幕亚洲综合小综合在线 | 亚洲狠狠爱综合影院婷婷| 国产91色综合久久免费分享| 成人免费ā片在线观看| 亚洲av无码日韩av无码网站冲| 亚洲理论精品午夜电影| 亚洲AV无码乱码国产麻豆穿越| 日韩免费观看视频| 免费国产作爱视频网站| 成全视频免费观看在线看| 美女18一级毛片免费看| 亚洲三级在线播放| 亚洲视频2020| 亚洲成AV人片在线观看无码| 亚洲日韩在线观看免费视频| 国产免费人成视频在线观看| 成年在线观看网站免费|