本篇內(nèi)容主要講解“怎么用JAVA實現(xiàn)簡單Thread緩沖池”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“怎么用JAVA實現(xiàn)簡單Thread緩沖池”吧!
創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供廣河網(wǎng)站建設(shè)、廣河做網(wǎng)站、廣河網(wǎng)站設(shè)計、廣河網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、廣河企業(yè)網(wǎng)站模板建站服務(wù),10多年廣河做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。
在應(yīng)用中,我們常常需要Thread緩沖池來做一些事以提高程序的效率和并發(fā)性。本文演示了如何利用Queue這種數(shù)據(jù)結(jié)構(gòu)實現(xiàn)一個簡單的Thread緩沖池。
一個Thread緩沖池可以設(shè)計成以下這樣:緩沖池由幾個工作Thread和一個Queue組成,Client負責把任務(wù)放到Queue里面(put方法),而工作Thread就依次取出這些任務(wù)并執(zhí)行它們(get方法)。
Queue的一個經(jīng)典實現(xiàn)是使用一個循環(huán)數(shù)組(這個實現(xiàn)在很多數(shù)據(jù)結(jié)構(gòu)的書上都有介紹),如一個大小為size的數(shù)組,這個循環(huán)數(shù)組可以被想象成首尾相連的一個環(huán)。oldest指向Queue中最老的數(shù)據(jù)所在的位置,next指向下一個可以放新數(shù)據(jù)的位置。
放入一個新數(shù)據(jù)到next的位置后,需要更新next:next = (next + 1) % size;
從oldest位置取出一個數(shù)據(jù)后,需要更新oldest:oldest = (oldest + 1) % size;
當oldest == next的時候,Queue為空,
當(next + 1) % size == oldest的時候,Queue為滿。
(注意:為了區(qū)分Queue為空和為滿的情況,實際上Queue里面最多能放size-1個數(shù)據(jù)。)
因為這個Queue會同時被多個線程訪問,需要考慮在這種情況下Queue如何工作。首先,Queue需要是線程安全的,可以用Java里的synchronized關(guān)鍵字來確保同時只有一個Thread在訪問Queue.
我們還可以注意到當Queue為空的時候,get操作是無法進行的;當Queue為滿的時候,put操作又是無法進行的。在多線程訪問遇到這種情況時,一般希望執(zhí)行操作的線程可以等待(block)直到該操作可以進行下去。比如,但一個Thread在一個空Queue上執(zhí)行g(shù)et方法的時候,這個 Thread應(yīng)當?shù)却?block),直到另外的Thread執(zhí)行該Queue的put方法后,再繼續(xù)執(zhí)行下去。在Java里面,Object對象的 wait(),notify()方法提供了這樣的功能。
把上面的內(nèi)容結(jié)合起來,就是一個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一文。
接下來我們需要一個對象來表現(xiàn)Thread緩沖池所要執(zhí)行的任務(wù)??梢园l(fā)現(xiàn)JDK中的Runnable interface非常合適這個角色。
最后,剩下工作線程的實現(xiàn)就很簡單了:從SyncQueue里取出一個Runnable對象并執(zhí)行它。
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緩沖池的例子:
//構(gòu)造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緩沖池的實現(xiàn)是一個基本的框架。當使用到實際中時,一些其他功能也可以在這一基礎(chǔ)上添加,比如異常處理,動態(tài)調(diào)整緩沖池大小等等。
到此,相信大家對“怎么用JAVA實現(xiàn)簡單Thread緩沖池”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!
本文標題:怎么用JAVA實現(xiàn)簡單Thread緩沖池
分享網(wǎng)址:http://m.rwnh.cn/article32/jejepc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計公司、軟件開發(fā)、全網(wǎng)營銷推廣、網(wǎng)站營銷、網(wǎng)站維護、ChatGPT
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)