java線程并發(fā)blockingqueue類使用示例
如果BlockingQueue是滿的任何試圖往里存東西的操作也會被阻斷進(jìn)入等待狀態(tài),直到BlockingQueue里有新的空間才會被喚醒繼續(xù)操作。
BlockingQueue提供的方法主要有:
add(anObject): 把a(bǔ)nObject加到BlockingQueue里,如果BlockingQueue可以容納返回true,否則拋出IllegalStateException異常。
offer(anObject):把a(bǔ)nObject加到BlockingQueue里,如果BlockingQueue可以容納返回true,否則返回false。
put(anObject):把a(bǔ)nObject加到BlockingQueue里,如果BlockingQueue沒有空間,調(diào)用此方法的線程被阻斷直到BlockingQueue里有新的空間再繼續(xù)。
poll(time):取出BlockingQueue里排在首位的對象,若不能立即取出可等time參數(shù)規(guī)定的時間。取不到時返回null。
take():取出BlockingQueue里排在首位的對象,若BlockingQueue為空,阻斷進(jìn)入等待狀態(tài)直到BlockingQueue有新的對象被加入為止。
根據(jù)不同的需要BlockingQueue有4種具體實(shí)現(xiàn):
(1)ArrayBlockingQueue:規(guī)定大小的BlockingQueue,其構(gòu)造函數(shù)必須帶一個int參數(shù)來指明其大小。其所含的對象是以FIFO(先入先出)順序排序的。
(2)LinkedBlockingQueue:大小不定的BlockingQueue,若其構(gòu)造函數(shù)帶一個規(guī)定大小的參數(shù),生成的BlockingQueue有大小限制,
若不帶大小參數(shù),所生成的BlockingQueue的大小由Integer.MAX_VALUE來決定。其所含的對象是以FIFO(先入先出)順序排序的。
LinkedBlockingQueue和ArrayBlockingQueue比較起來,它們背后所用的數(shù)據(jù)結(jié)構(gòu)不一樣,
導(dǎo)致LinkedBlockingQueue的數(shù)據(jù)吞吐量要大于ArrayBlockingQueue,但在線程數(shù)量很大時其性能的可預(yù)見性低于ArrayBlockingQueue。
(3)PriorityBlockingQueue:類似于LinkedBlockingQueue,但其所含對象的排序不是FIFO,而是依據(jù)對象的自然排序順序或者是構(gòu)造函數(shù)所帶的Comparator決定的順序。
(4)SynchronousQueue:特殊的BlockingQueue,對其的操作必須是放和取交替完成的。
package com.yao;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class BlockingQueueTest {
/**
定義裝蘋果的籃子
*/
public static class Basket{
// 籃子,能夠容納3個蘋果
BlockingQueue<String> basket = new ArrayBlockingQueue<String>(3);
// 生產(chǎn)蘋果,放入籃子
public void produce() throws InterruptedException{
// put方法放入一個蘋果,若basket滿了,等到basket有位置
basket.put("An apple");
}
// 消費(fèi)蘋果,從籃子中取走
public String consume() throws InterruptedException{
// get方法取出一個蘋果,若basket為空,等到basket有蘋果為止
String apple = basket.take();
return apple;
}
public int getAppleNumber(){
return basket.size();
}
}
// 測試方法
public static void testBasket() {
// 建立一個裝蘋果的籃子
final Basket basket = new Basket();
// 定義蘋果生產(chǎn)者
class Producer implements Runnable {
public void run() {
try {
while (true) {
// 生產(chǎn)蘋果
System.out.println("生產(chǎn)者準(zhǔn)備生產(chǎn)蘋果:"
+ System.currentTimeMillis());
basket.produce();
System.out.println("生產(chǎn)者生產(chǎn)蘋果完畢:"
+ System.currentTimeMillis());
System.out.println("生產(chǎn)完后有蘋果:"+basket.getAppleNumber()+"個");
// 休眠300ms
Thread.sleep(300);
}
} catch (InterruptedException ex) {
}
}
}
// 定義蘋果消費(fèi)者
class Consumer implements Runnable {
public void run() {
try {
while (true) {
// 消費(fèi)蘋果
System.out.println("消費(fèi)者準(zhǔn)備消費(fèi)蘋果:"
+ System.currentTimeMillis());
basket.consume();
System.out.println("消費(fèi)者消費(fèi)蘋果完畢:"
+ System.currentTimeMillis());
System.out.println("消費(fèi)完后有蘋果:"+basket.getAppleNumber()+"個");
// 休眠1000ms
Thread.sleep(1000);
}
} catch (InterruptedException ex) {
}
}
}
ExecutorService service = Executors.newCachedThreadPool();
Producer producer = new Producer();
Consumer consumer = new Consumer();
service.submit(producer);
service.submit(consumer);
// 程序運(yùn)行10s后,所有任務(wù)停止
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
}
service.shutdownNow();
}
public static void main(String[] args) {
BlockingQueueTest.testBasket();
}
}
- 深入解析Java中ThreadLocal線程類的作用和用法
- java實(shí)現(xiàn)適用于安卓的文件下載線程類
- java多線程并發(fā)executorservice(任務(wù)調(diào)度)類
- java線程之用Thread類創(chuàng)建線程的方法
- 詳談Java幾種線程池類型介紹及使用方法
- java多線程編程之使用Synchronized關(guān)鍵字同步類方法
- java多線程并發(fā)中使用Lockers類將多線程共享資源鎖定
- java線程并發(fā)countdownlatch類使用示例
- java多線程Future和Callable類示例分享
- java 可重啟線程及線程池類的設(shè)計(jì)(詳解)
- Java多線程繼承Thread類詳解
- Java繼承Thread類創(chuàng)建線程類示例
相關(guān)文章
Springboot集成Jasypt實(shí)現(xiàn)配置文件加密的方法
Jasypt是一個java庫,它允許開發(fā)員以最少的努力為他/她的項(xiàng)目添加基本的加密功能,并且不需要對加密工作原理有深入的了解,這篇文章主要介紹了Springboot集成Jasypt實(shí)現(xiàn)配置文件加密,需要的朋友可以參考下2023-04-04線程池ThreadPoolExecutor并行處理實(shí)現(xiàn)代碼
這篇文章主要介紹了線程池ThreadPoolExecutor并行處理實(shí)現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-11-11redis redisson 限流器的實(shí)例(RRateLimiter)
這篇文章主要介紹了redis redisson 限流器的實(shí)例(RRateLimiter),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07JDK數(shù)組阻塞隊(duì)列源碼深入分析總結(jié)
在這篇文章當(dāng)中,我們將通過源碼仔細(xì)為大家介紹一下JDK具體是如何實(shí)現(xiàn)數(shù)組阻塞隊(duì)列的,文中的示例代碼講解詳細(xì),感興趣的可以了解一下2022-08-08java普通項(xiàng)目讀取不到resources目錄下資源文件的解決辦法
這篇文章主要給大家介紹了關(guān)于java普通項(xiàng)目讀取不到resources目錄下資源文件的解決辦法,Web項(xiàng)目中應(yīng)該經(jīng)常有這樣的需求,在maven項(xiàng)目的resources目錄下放一些文件,比如一些配置文件,資源文件等,需要的朋友可以參考下2023-09-09Java并發(fā)編程之詳解ConcurrentHashMap類
在之前的文章中已經(jīng)為大家介紹了java并發(fā)編程的工具:BlockingQueue接口、ArrayBlockingQueue、DelayQueue、LinkedBlockingQueue、PriorityBlockingQueue、SynchronousQueue、BlockingDeque接口,本文為系列文章第八篇.需要的朋友可以參考下2021-06-06解決SpringBoot使用devtools導(dǎo)致的類型轉(zhuǎn)換異常問題
這篇文章主要介紹了解決SpringBoot使用devtools導(dǎo)致的類型轉(zhuǎn)換異常問題,具有很好的參考價值,希望對大家有所幫助。 一起跟隨小編過來看看吧2020-08-08