亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

JAVA進階:一個簡單Thread緩沖池的實現

2023-06-11 14:56:26
字體:
來源:轉載
供稿:網友

在應用中,我們常常需要Thread緩沖池來做一些事以提高程序的效率和并發性。本文演示了如何利用Queue這種數據結構實現一個簡單的Thread緩沖池。

一個Thread緩沖池可以設計成以下這樣:緩沖池由幾個工作Thread和一個Queue組成,Client負責把任務放到Queue里面(put方法),而工作Thread就依次取出這些任務并執行它們(get方法)。

Queue的一個經典實現是使用一個循環數組(這個實現在很多數據結構的書上都有介紹),如一個大小為size的數組,這個循環數組可以被想象成首尾相連的一個環。oldest指向Queue中最老的數據所在的位置,next指向下一個可以放新數據的位置。

放入一個新數據到next的位置后,需要更新next:next = (next + 1) % size;

從oldest位置取出一個數據后,需要更新oldest:oldest = (oldest + 1) % size;

當oldest == next的時候,Queue為空,

當(next + 1) % size == oldest的時候,Queue為滿。

(注意:為了區分Queue為空和為滿的情況,實際上Queue里面最多能放size-1個數據。)

因為這個Queue會同時被多個線程訪問,需要考慮在這種情況下Queue如何工作。首先,Queue需要是線程安全的,可以用Java里的synchronized關鍵字來確保同時只有一個Thread在訪問Queue.

我們還可以注意到當Queue為空的時候,get操作是無法進行的;當Queue為滿的時候,put操作又是無法進行的。在多線程訪問遇到這種情況時,一般希望執行操作的線程可以等待(block)直到該操作可以進行下去。比如,但一個Thread在一個空Queue上執行get方法的時候,這個 Thread應當等待(block),直到另外的Thread執行該Queue的put方法后,再繼續執行下去。在Java里面,Object對象的 wait(),notify()方法提供了這樣的功能。

把上面的內容結合起來,就是一個SyncQueue的類:

public class SyncQueue {

    public SyncQueue(int size) {
       _array = new Object[size];
       _size = size;
       _oldest = 0;
       _next = 0;
    }

    public synchronized void put(Object o) {
       while (full()) {
           try {
              wait();
           } catch (InterruptedException ex) {
              throw new ExceptionAdapter(ex);
           }
       }
       _array[_next] = o;
       _next = (_next + 1) % _size;
       notify();
    }

    public synchronized Object get() {
       while (empty()) {
           try {
              wait();
           } catch (InterruptedException ex) {
              throw new ExceptionAdapter(ex);
           }
       }
       Object ret = _array[_oldest];
       _oldest = (_oldest + 1) % _size;
       notify();
       return ret;
    }

    protected boolean empty() {
       return _next == _oldest;
    }

    protected boolean full() {
       return (_next + 1) % _size == _oldest;
    }

    protected Object [] _array;
    protected int _next;
    protected int _oldest;
    protected int _size;
}
 
可以注意一下get和put方法中while的使用,如果換成if是會有問題的。這是個很容易犯的錯誤。;-)
在以上代碼中使用了ExceptionAdapter這個類,它的作用是把一個checked Exception包裝成RuntimeException。詳細的說明可以參考我的避免在Java中使用Checked Exception一文。

接下來我們需要一個對象來表現Thread緩沖池所要執行的任務??梢园l現JDK中的Runnable interface非常合適這個角色。

最后,剩下工作線程的實現就很簡單了:從SyncQueue里取出一個Runnable對象并執行它。

public class Worker implements Runnable {

    public Worker(SyncQueue queue) {
       _queue = queue;
    }

    public void run() {
       while (true) {
           Runnable task = (Runnable) _queue.get();
           task.run();
       }
    }

    protected SyncQueue _queue = null;

}

下面是一個使用這個Thread緩沖池的例子:

       //構造Thread緩沖池
       SyncQueue queue = new SyncQueue(10);
       for (int i = 0; i < 5; i ++) {
           new Thread(new Worker(queue)).start();
       }   
       //使用Thread緩沖池
       Runnable task = new MyTask();
       queue.put(task);

為了使本文中的代碼盡可能簡單,這個Thread緩沖池的實現是一個基本的框架。當使用到實際中時,一些其他功能也可以在這一基礎上添加,比如異常處理,動態調整緩沖池大小等等。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91tv亚洲精品香蕉国产一区7ujn| 亚洲视频免费一区| 国产一区二区三区在线视频| 国产精品美女久久久久久免费| 欧美在线观看日本一区| 欧美多人爱爱视频网站| 欧美性xxxx极品高清hd直播| 亚洲在线免费看| 色噜噜国产精品视频一区二区| 俺也去精品视频在线观看| 亚洲人成人99网站| 国产在线精品自拍| 欧美超级免费视 在线| 国产在线一区二区三区| 国产精品久久久久久av福利| 亚洲精品自产拍| 国模吧一区二区三区| 51精品在线观看| 秋霞av国产精品一区| 欧美亚洲另类视频| 萌白酱国产一区二区| 久久97久久97精品免视看| 亚洲精品之草原avav久久| 欧美精品一区二区免费| 亚洲无限乱码一二三四麻| 欧美国产日韩在线| 久久久久久一区二区三区| 91香蕉嫩草影院入口| 亚洲日韩中文字幕| 精品美女国产在线| 精品久久久久久久久久ntr影视| 少妇高潮久久久久久潘金莲| 亚洲精品美女网站| 久久躁日日躁aaaaxxxx| 日韩av影视在线| 国产在线观看91精品一区| 久久伊人色综合| 欧美精品久久久久| 亚洲精品国产福利| 久久久久久久网站| 日韩在线不卡视频| 亚洲精品久久久久久久久久久久久| 美女视频黄免费的亚洲男人天堂| 成人精品一区二区三区电影黑人| 成人国产在线激情| 国产99久久精品一区二区| 久久亚洲国产精品成人av秋霞| 欲色天天网综合久久| 2025国产精品视频| 亚洲国产精品嫩草影院久久| 欧美激情二区三区| 欧美伊久线香蕉线新在线| 黑人狂躁日本妞一区二区三区| 国产精品自在线| 欧美黑人极品猛少妇色xxxxx| 国产亚洲精品美女久久久| 国产精品网红福利| 日韩精品极品视频| 国产精品视频xxx| 奇门遁甲1982国语版免费观看高清| 日韩av中文字幕在线免费观看| 日本91av在线播放| 日韩久久精品成人| 精品欧美一区二区三区| 中文字幕亚洲综合久久| 亚洲欧美国产精品va在线观看| 欧美黄色三级网站| 中文字幕精品网| 亚洲成年人影院在线| 欧美日韩激情视频| 欧美日产国产成人免费图片| 欧美精品激情blacked18| 国产精品成人av性教育| 97涩涩爰在线观看亚洲| 亚洲日本aⅴ片在线观看香蕉| 亚洲欧美日韩国产中文| 国产精品成人在线| 色婷婷综合久久久久中文字幕1| 亚洲国产精品女人久久久| 国产亚洲一区二区在线| 日本精品久久久久影院| 欧美性猛交xxxx免费看| 久久亚洲国产精品| 国产盗摄xxxx视频xxx69| 久久久久久久av| 亚洲欧美在线播放| 亚洲久久久久久久久久久| 亚洲欧美日韩成人| 91久久嫩草影院一区二区| 亚洲女人被黑人巨大进入al| 久久精品国产久精国产思思| 日本高清+成人网在线观看| 亚洲加勒比久久88色综合| 伊人伊成久久人综合网小说| 中文字幕日韩专区| 欧美大秀在线观看| 欧美激情亚洲综合一区| 国产在线观看不卡| 日韩亚洲成人av在线| 欧美一级片久久久久久久| 国语自产精品视频在线看一大j8| 久久这里有精品视频| 久久九九有精品国产23| 综合激情国产一区| 欧洲成人在线观看| 亚洲第一级黄色片| 亚洲第一区中文字幕| 亚洲精品一区av在线播放| 丰满岳妇乱一区二区三区| 亚洲精品一区二区在线| 日韩电影在线观看中文字幕| 亚洲电影免费观看高清完整版| 97国产精品人人爽人人做| 精品成人国产在线观看男人呻吟| 欧美激情在线视频二区| 日韩在线观看免费全集电视剧网站| 91精品国产网站| 一道本无吗dⅴd在线播放一区| 久久视频精品在线| 成人欧美一区二区三区在线湿哒哒| 亚洲一级一级97网| 亚洲第一av网| 久久国产视频网站| 亚洲欧美中文在线视频| 亚洲**2019国产| 成人福利在线观看| 亚洲欧美国产高清va在线播| 国产深夜精品福利| 国产精品久久久久91| 欧美日韩国产第一页| 日韩综合视频在线观看| 欧美激情a∨在线视频播放| 久久成人人人人精品欧| 国产精欧美一区二区三区| 九九视频直播综合网| 亚洲国产精品va在看黑人| 欧美激情奇米色| 国产精品三级久久久久久电影| 国产精品午夜国产小视频| 国产偷亚洲偷欧美偷精品| 91亚洲午夜在线| 亚洲成人999| 日韩电影免费观看在线观看| 亚洲精品国产综合区久久久久久久| 国产精品中文字幕久久久| 81精品国产乱码久久久久久| 成人在线免费观看视视频| 欧美日韩中文字幕日韩欧美| 欧美做受高潮1| 国产精品极品美女粉嫩高清在线| 日韩av影视综合网| 欧美激情久久久| 欧美极品在线视频| 色哟哟亚洲精品一区二区| 久久成人人人人精品欧| 69视频在线免费观看| 久久九九有精品国产23| 欧美超级免费视 在线| 丝袜亚洲欧美日韩综合| 国产日韩换脸av一区在线观看| 欧美午夜激情小视频| 国产成人精彩在线视频九色| 国产精品久久久久久久久久久久久| 久久这里只有精品99|