国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 開發 > 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緩沖池所要執行的任務。可以發現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緩沖池的實現是一個基本的框架。當使用到實際中時,一些其他功能也可以在這一基礎上添加,比如異常處理,動態調整緩沖池大小等等。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
四虎www视频| 国产精品国产三级国产试看| 国产日产一区二区三区| 国产精品外围在线观看| 中文字幕有码在线视频| 国产精品ⅴa有声小说| 9999在线视频| 日本高清中文字幕二区在线| 激情亚洲综合网| 国产色婷婷在线| 国产亚洲精品久久久久久移动网络 | 国产二区三区四区| 日本免费视频www| 国产在线色视频| 国产天堂在线观看| 伊人免费视频| 最新天堂资源在线| 人日人天天爽| 在线视频中文字幕久| 国产综合视频一区二区三区免费| 国产高清免费av在线| www.狠狠操| 最近中文字幕mv2018在线高清| 999国产在线视频| 国产专区在线播放| eeuss影院www在线播放| 国产福利小视频在线观看| 日本欧洲一区| 精品剧情v国产在线观看| 国精一区二区三区| av片在线观看永久免费| 国产日产一区二区| 国产男女无套在线播放| 欧洲有码在线视频| www.三级.com| 青娱乐在线视频观看| 99在线欧洲视频| 国产小视频福利在线| 黄色免费av| 二人午夜免费观看在线视频| 免费a级人成a大片在线观看| 日本啊v在线| 欧美色第一页| 青青久在线视频免费观看| 在线看黄色av| 日本欧美在线视频免费观看| 青草视频在线播放| 久久精品视频观看| 福利视频在线看| 国产中文字幕在线| 国产一区二区三区不卡免费观看| 国产乱码在线| 国产在线视频自拍| 天天av天天爽| 中文av资源在线| 欧美色欧美亚洲另类二区精品 | 亚洲欧洲成人| 国产在线麻豆精品| 国产探花视频在线观看| 2018狠狠干| 人人在线视频| 国产偷倩在线播放| 亚洲an天堂an在线观看| 欧美a免费在线| 天堂在线亚洲| 在线中文资源天堂| 国产毛片在线看| 中文在线视频观看| 欧美高清xxxx性| 国产精品视频流白浆免费视频 | 91极品在线| 久久久久久久久亚洲精品| 国产无遮挡又黄又爽免费网站 | wwww在线观看免费视频| 亚色视频在线观看| 国产免费高清| av色在线观看| 国产福利在线观看| 国产麻豆视频网站| 亚洲一区二区三区在线观看网站| 国产自产视频| 日本电影全部在线观看网站视频| 中文字幕第一页av| 成人午夜无人区一区二区| 性色视频在线| 国产对白叫床清晰在线播放| 狠狠操五月天| 亚洲成人av高清| 97福利电影| 久久精品视频免费看| 精品极品三级久久久久| 在线91av| 午夜国产在线| 国产美女在线播放| 久久精品最新免费国产成人| 日本成人在线播放| 欧洲有码在线视频| 激情综合丁香| 国产麻豆精品高清在线播放| 青青在线视频| 久久亚洲国产成人亚| 轻轻色免费在线视频| 性网站在线播放| av在线不卡播放| av在线电影观看| 日本视频在线| 九九热精品在线视频| 中文字幕不卡| 国产黄色免费在线观看| 精灵使的剑舞无删减版在线观看| 精品久久亚洲一级α| 日本在线观看网站| 成人精品一区二区三区免费| 1区不卡电影| 亚洲高清在线免费| 黄网站在线观看高清免费| 高清av中文在线字幕观看1| 国产乱精品一区二区三区| 国产一二三视频| 99免费视频| www在线播放| 99视频免费| 在线视频中文字幕| 超碰免费97在线观看| 国产一二区视频| wwwww在线观看免费视频| 免费观看v片在线观看| 国产亚洲精品久久久久久青梅 | 丁香六月婷婷| 国产精品欧美色图| 精品久久亚洲一级α| 青草在线视频在线观看| 五月天天在线| gogogogo高清视频在线| 国产无遮挡在线视频免费观看| 在线观看的av| 最近中文字幕mv免费高清电影| 亚洲视频网站在线| 国产精品视频一区二区久久 | 本道综合精品| 国产91久久久久蜜臀青青天草二| 本道综合精品| 国产对白国语对白| 免费av不卡在线观看| 精品国产免费第一区二区| 国产性一级片| 丁香婷婷在线| www.av在线播放| 国产不卡精品一区二区三区| 国产69精品久久app免费版 | 精品国内一区二区三区免费视频 | 九九在线视频| wwwww在线观看免费视频| 国产极品视频| 中文字幕不卡免费视频| 九九热视频免费在线观看| 永久av在线| 在线视频福利| 亚洲精品自拍区在线观看| 国产l精品国产亚洲区在线观看| 99视频在线观看地址| 国产中文字幕在线看| 超碰免费在线播放| 在线观看的av| 亚洲精品乱码电影在线观看| av大片在线播放| 97中文字幕| 天天噜天天色| 超碰在线网址| 福利在线观看| 国产精品久久久久白浆| 国产高清在线| 亚洲视频精品在线观看| www免费在线观看| 就爱干草视频| 国产免费电影网站入口| 中文字幕在线永久在线视频| 国产午夜三区视频在线| 国产日韩网站| 亚洲夜夜综合| 国产尤物视频| 精品av中文字幕在线毛片| jizz国产| 国产美女视频网站| 2019中文字幕视频| 欧美日韩在线视频免费观看| 国产专区在线| 精品久久av| 国产在线看片| 69久久久久| 国产精品臀控福利在线观看| 91最新在线| 成人超碰在线| 精品av中文字幕在线毛片| 久久精品国产亚洲777| 国产视频精选在线| 麻豆精品传媒视频观看| av福利在线播放| 国产激情二区| 国产视频精选在线|