java線程并發(fā)blockingqueue類(lèi)使用示例
如果BlockingQueue是滿(mǎn)的任何試圖往里存東西的操作也會(huì)被阻斷進(jìn)入等待狀態(tài),直到BlockingQueue里有新的空間才會(huì)被喚醒繼續(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沒(méi)有空間,調(diào)用此方法的線程被阻斷直到BlockingQueue里有新的空間再繼續(xù)。
poll(time):取出BlockingQueue里排在首位的對(duì)象,若不能立即取出可等time參數(shù)規(guī)定的時(shí)間。取不到時(shí)返回null。
take():取出BlockingQueue里排在首位的對(duì)象,若BlockingQueue為空,阻斷進(jìn)入等待狀態(tài)直到BlockingQueue有新的對(duì)象被加入為止。
根據(jù)不同的需要BlockingQueue有4種具體實(shí)現(xiàn):
(1)ArrayBlockingQueue:規(guī)定大小的BlockingQueue,其構(gòu)造函數(shù)必須帶一個(gè)int參數(shù)來(lái)指明其大小。其所含的對(duì)象是以FIFO(先入先出)順序排序的。
(2)LinkedBlockingQueue:大小不定的BlockingQueue,若其構(gòu)造函數(shù)帶一個(gè)規(guī)定大小的參數(shù),生成的BlockingQueue有大小限制,
若不帶大小參數(shù),所生成的BlockingQueue的大小由Integer.MAX_VALUE來(lái)決定。其所含的對(duì)象是以FIFO(先入先出)順序排序的。
LinkedBlockingQueue和ArrayBlockingQueue比較起來(lái),它們背后所用的數(shù)據(jù)結(jié)構(gòu)不一樣,
導(dǎo)致LinkedBlockingQueue的數(shù)據(jù)吞吐量要大于ArrayBlockingQueue,但在線程數(shù)量很大時(shí)其性能的可預(yù)見(jiàn)性低于ArrayBlockingQueue。
(3)PriorityBlockingQueue:類(lèi)似于LinkedBlockingQueue,但其所含對(duì)象的排序不是FIFO,而是依據(jù)對(duì)象的自然排序順序或者是構(gòu)造函數(shù)所帶的Comparator決定的順序。
(4)SynchronousQueue:特殊的BlockingQueue,對(duì)其的操作必須是放和取交替完成的。
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 {
/**
定義裝蘋(píng)果的籃子
*/
public static class Basket{
// 籃子,能夠容納3個(gè)蘋(píng)果
BlockingQueue<String> basket = new ArrayBlockingQueue<String>(3);
// 生產(chǎn)蘋(píng)果,放入籃子
public void produce() throws InterruptedException{
// put方法放入一個(gè)蘋(píng)果,若basket滿(mǎn)了,等到basket有位置
basket.put("An apple");
}
// 消費(fèi)蘋(píng)果,從籃子中取走
public String consume() throws InterruptedException{
// get方法取出一個(gè)蘋(píng)果,若basket為空,等到basket有蘋(píng)果為止
String apple = basket.take();
return apple;
}
public int getAppleNumber(){
return basket.size();
}
}
// 測(cè)試方法
public static void testBasket() {
// 建立一個(gè)裝蘋(píng)果的籃子
final Basket basket = new Basket();
// 定義蘋(píng)果生產(chǎn)者
class Producer implements Runnable {
public void run() {
try {
while (true) {
// 生產(chǎn)蘋(píng)果
System.out.println("生產(chǎn)者準(zhǔn)備生產(chǎn)蘋(píng)果:"
+ System.currentTimeMillis());
basket.produce();
System.out.println("生產(chǎn)者生產(chǎn)蘋(píng)果完畢:"
+ System.currentTimeMillis());
System.out.println("生產(chǎn)完后有蘋(píng)果:"+basket.getAppleNumber()+"個(gè)");
// 休眠300ms
Thread.sleep(300);
}
} catch (InterruptedException ex) {
}
}
}
// 定義蘋(píng)果消費(fèi)者
class Consumer implements Runnable {
public void run() {
try {
while (true) {
// 消費(fèi)蘋(píng)果
System.out.println("消費(fèi)者準(zhǔn)備消費(fèi)蘋(píng)果:"
+ System.currentTimeMillis());
basket.consume();
System.out.println("消費(fèi)者消費(fèi)蘋(píng)果完畢:"
+ System.currentTimeMillis());
System.out.println("消費(fèi)完后有蘋(píng)果:"+basket.getAppleNumber()+"個(gè)");
// 休眠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線程類(lèi)的作用和用法
- java實(shí)現(xiàn)適用于安卓的文件下載線程類(lèi)
- java多線程并發(fā)executorservice(任務(wù)調(diào)度)類(lèi)
- java線程之用Thread類(lèi)創(chuàng)建線程的方法
- 詳談Java幾種線程池類(lèi)型介紹及使用方法
- java多線程編程之使用Synchronized關(guān)鍵字同步類(lèi)方法
- java多線程并發(fā)中使用Lockers類(lèi)將多線程共享資源鎖定
- java線程并發(fā)countdownlatch類(lèi)使用示例
- java多線程Future和Callable類(lèi)示例分享
- java 可重啟線程及線程池類(lèi)的設(shè)計(jì)(詳解)
- Java多線程繼承Thread類(lèi)詳解
- Java繼承Thread類(lèi)創(chuàng)建線程類(lèi)示例
相關(guān)文章
最全JVM調(diào)優(yōu)步驟和參數(shù)及配置
這篇文章主要給大家介紹了關(guān)于JVM調(diào)優(yōu)的相關(guān)資料,JVM調(diào)優(yōu)是指對(duì)Java虛擬機(jī)(JVM)進(jìn)行優(yōu)化,以提高Java程序的性能和運(yùn)行效率,文中介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03
jedispool連redis高并發(fā)卡死的問(wèn)題
本篇文章主要介紹了jedispool連redis高并發(fā)卡死的問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
selenium+java環(huán)境搭建過(guò)程推薦
這篇文章主要介紹了selenium+java環(huán)境搭建過(guò)程推薦,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10
feign客戶(hù)端設(shè)置超時(shí)時(shí)間操作
這篇文章主要介紹了feign客戶(hù)端設(shè)置超時(shí)時(shí)間操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09
SpringBoot+Redis實(shí)現(xiàn)分布式緩存的方法步驟
在高并發(fā)的分布式的系統(tǒng)中,緩存是提升系統(tǒng)性能的重要手段,本文主要介紹了SpringBoot+Redis實(shí)現(xiàn)分布式緩存的方法步驟,具有一定的參考價(jià)值,感興趣的可以了解一下2024-07-07
SpringBoot和Vue2項(xiàng)目配置https協(xié)議過(guò)程
本文詳細(xì)介紹了SpringBoot項(xiàng)目和Vue2項(xiàng)目的部署流程及SSL證書(shū)配置,對(duì)于SpringBoot項(xiàng)目,需將.pfx文件放入resources目錄并配置server,然后打包部署,Vue2項(xiàng)目中,涉及檢查nginx的SSL模塊、編譯新的nginx文件2024-10-10
SpringCloud微服務(wù)調(diào)用丟失請(qǐng)求頭的問(wèn)題及解決方案
在Spring Cloud 中微服務(wù)之間的調(diào)用會(huì)用到Feign,但是在默認(rèn)情況下,Feign 調(diào)用遠(yuǎn)程服務(wù)存在Header請(qǐng)求頭丟失問(wèn)題,下面給大家分享SpringCloud微服務(wù)調(diào)用丟失請(qǐng)求頭的問(wèn)題及解決方案,感興趣的朋友一起看看吧2024-02-02

