日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

淺談Java中的Queue家族

瀏覽:229日期:2022-08-11 14:00:57
目錄Queue接口Queue的分類BlockingQueueDequeTransferQueueQueue接口

先看下Queue的繼承關系和其中定義的方法:

淺談Java中的Queue家族

Queue繼承自Collection,Collection繼承自Iterable。

Queue有三類主要的方法,我們用個表格來看一下他們的區別:

方法類型 方法名稱 方法名稱 區別 Insert add offer 兩個方法都表示向Queue中添加某個元素,不同之處在于添加失敗的情況,add只會返回true,如果添加失敗,會拋出異常。offer在添加失敗的時候會返回false。所以對那些有固定長度的Queue,優先使用offer方法。 Remove remove poll 如果Queue是空的情況下,remove會拋出異常,而poll會返回null。 Examine element peek 獲取Queue頭部的元素,但不從Queue中刪除。兩者的區別還是在于Queue為空的情況下,element會拋出異常,而peek返回null。

注意,因為對poll和peek來說null是有特殊含義的,所以一般來說Queue中禁止插入null,但是在實現中還是有一些類允許插入null比如LinkedList。

盡管如此,我們在使用中還是要避免插入null元素。

Queue的分類

一般來說Queue可以分為BlockingQueue,Deque和TransferQueue三種。

BlockingQueue

BlockingQueue是Queue的一種實現,它提供了兩種額外的功能:

當當前Queue是空的時候,從BlockingQueue中獲取元素的操作會被阻塞。當當前Queue達到最大容量的時候,插入BlockingQueue的操作會被阻塞。

BlockingQueue的操作可以分為下面四類:

操作類型Throws exceptionSpecial valueBlocksTimes outInsertadd(e)offer(e)put(e)offer(e, time, unit)Removeremove()poll()take()poll(time, unit)Examineelement()peek()not applicablenot applicable

第一類是會拋出異常的操作,當遇到插入失敗,隊列為空的時候拋出異常。

第二類是不會拋出異常的操作。

第三類是會Block的操作。當Queue為空或者達到最大容量的時候。

第四類是time out的操作,在給定的時間里會Block,超時會直接返回。

BlockingQueue是線程安全的Queue,可以在生產者消費者模式的多線程中使用,如下所示:

class Producer implements Runnable { private final BlockingQueue queue; Producer(BlockingQueue q) { queue = q; } public void run() { try { while (true) { queue.put(produce()); } } catch (InterruptedException ex) { ... handle ...} } Object produce() { ... } } class Consumer implements Runnable { private final BlockingQueue queue; Consumer(BlockingQueue q) { queue = q; } public void run() { try { while (true) { consume(queue.take()); } } catch (InterruptedException ex) { ... handle ...} } void consume(Object x) { ... } } class Setup { void main() { BlockingQueue q = new SomeQueueImplementation(); Producer p = new Producer(q); Consumer c1 = new Consumer(q); Consumer c2 = new Consumer(q); new Thread(p).start(); new Thread(c1).start(); new Thread(c2).start(); } }

最后,在一個線程中向BlockQueue中插入元素之前的操作happens-before另外一個線程中從BlockQueue中刪除或者獲取的操作。

Deque

Deque是Queue的子類,它代表double ended queue,也就是說可以從Queue的頭部或者尾部插入和刪除元素。

同樣的,我們也可以將Deque的方法用下面的表格來表示,Deque的方法可以分為對頭部的操作和對尾部的操作:

方法類型 Throws exception Special value Throws exception Special value Insert addFirst(e) offerFirst(e) addLast(e) offerLast(e) Remove removeFirst() pollFirst() removeLast() pollLast() Examine getFirst() peekFirst() getLast() peekLast()

和Queue的方法描述基本一致,這里就不多講了。

當Deque以 FIFO (First-In-First-Out)的方法處理元素的時候,Deque就相當于一個Queue。

當Deque以LIFO (Last-In-First-Out)的方式處理元素的時候,Deque就相當于一個Stack。

TransferQueue

TransferQueue繼承自BlockingQueue,為什么叫Transfer呢?因為TransferQueue提供了一個transfer的方法,生產者可以調用這個transfer方法,從而等待消費者調用take或者poll方法從Queue中拿取數據。

還提供了非阻塞和timeout版本的tryTransfer方法以供使用。

我們舉個TransferQueue實現的生產者消費者的問題。

先定義一個生產者:

@Slf4j@Data@AllArgsConstructorclass Producer implements Runnable { private TransferQueue<String> transferQueue; private String name; private Integer messageCount; public static final AtomicInteger messageProduced = new AtomicInteger(); @Override public void run() {for (int i = 0; i < messageCount; i++) { try {boolean added = transferQueue.tryTransfer( '第'+i+'個', 2000, TimeUnit.MILLISECONDS);log.info('transfered {} 是否成功: {}','第'+i+'個',added);if(added){ messageProduced.incrementAndGet();} } catch (InterruptedException e) {log.error(e.getMessage(),e); }}log.info('total transfered {}',messageProduced.get()); }}

在生產者的run方法中,我們調用了tryTransfer方法,等待2秒鐘,如果沒成功則直接返回。

再定義一個消費者:

@Slf4j@Data@AllArgsConstructorpublic class Consumer implements Runnable { private TransferQueue<String> transferQueue; private String name; private int messageCount; public static final AtomicInteger messageConsumed = new AtomicInteger(); @Override public void run() {for (int i = 0; i < messageCount; i++) { try {String element = transferQueue.take();log.info('take {}',element );messageConsumed.incrementAndGet();Thread.sleep(500); } catch (InterruptedException e) {log.error(e.getMessage(),e); }}log.info('total consumed {}',messageConsumed.get()); }}

在run方法中,調用了transferQueue.take方法來取消息。

下面先看一下一個生產者,零個消費者的情況:

@Testpublic void testOneProduceZeroConsumer() throws InterruptedException { TransferQueue<String> transferQueue = new LinkedTransferQueue<>(); ExecutorService exService = Executors.newFixedThreadPool(10); Producer producer = new Producer(transferQueue, 'ProducerOne', 5); exService.execute(producer); exService.awaitTermination(50000, TimeUnit.MILLISECONDS); exService.shutdown();}

輸出結果:

[pool-1-thread-1] INFO com.flydean.Producer - transfered 第0個 是否成功: false

[pool-1-thread-1] INFO com.flydean.Producer - transfered 第1個 是否成功: false

[pool-1-thread-1] INFO com.flydean.Producer - transfered 第2個 是否成功: false

[pool-1-thread-1] INFO com.flydean.Producer - transfered 第3個 是否成功: false

[pool-1-thread-1] INFO com.flydean.Producer - transfered 第4個 是否成功: false

[pool-1-thread-1] INFO com.flydean.Producer - total transfered 0

可以看到,因為沒有消費者,所以消息并沒有發送成功。

再看下一個有消費者的情況:

@Testpublic void testOneProduceOneConsumer() throws InterruptedException { TransferQueue<String> transferQueue = new LinkedTransferQueue<>(); ExecutorService exService = Executors.newFixedThreadPool(10); Producer producer = new Producer(transferQueue, 'ProducerOne', 2); Consumer consumer = new Consumer(transferQueue, 'ConsumerOne', 2); exService.execute(producer); exService.execute(consumer); exService.awaitTermination(50000, TimeUnit.MILLISECONDS); exService.shutdown();}

輸出結果:

[pool-1-thread-2] INFO com.flydean.Consumer - take 第0個

[pool-1-thread-1] INFO com.flydean.Producer - transfered 第0個 是否成功: true

[pool-1-thread-2] INFO com.flydean.Consumer - take 第1個

[pool-1-thread-1] INFO com.flydean.Producer - transfered 第1個 是否成功: true

[pool-1-thread-1] INFO com.flydean.Producer - total transfered 2

[pool-1-thread-2] INFO com.flydean.Consumer - total consumed 2

可以看到Producer和Consumer是一個一個來生產和消費的。

以上就是淺談Java中的Queue家族的詳細內容,更多關于Java中的Queue家族的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美在线影院| 日韩欧美一区免费| 欧美中文字幕| 伊人久久成人| 老司机精品久久| 国产韩日影视精品| 欧美日韩精品免费观看视频完整| 国产农村妇女精品一区二区| 视频在线在亚洲| 天堂久久av| 国产精品久久久久久久久久齐齐| 国产精品一区二区美女视频免费看| 国产精品一二| 精品久久不卡| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 噜噜噜久久亚洲精品国产品小说| 国产精品毛片| 午夜性色一区二区三区免费视频| 97成人超碰| 国产在线不卡一区二区三区| 亚洲日本网址| 亚洲精选av| 精品少妇av| 久久九九电影| 亚洲精品美女| 精品国产乱码久久久久久樱花| 成人羞羞在线观看网站| 黄色亚洲精品| 欧美一区二区三区久久| 精品视频网站| 亚洲国产成人精品女人| 亚欧成人精品| 国产精品xx| 国产精品毛片| 国产精品久久久久久妇女| 国产不卡人人| 视频一区在线视频| 国产精品一区二区三区www| av资源中文在线天堂| aⅴ色国产欧美| 国产精品videosex极品| 99精品小视频| 影音先锋久久精品| 动漫av一区| 久久性天堂网| 国产一区调教| 久久国产88| 高清一区二区三区| 免费看精品久久片| 高清一区二区| 亚洲a级精品| 日韩在线第七页| 亚洲人妖在线| 亚洲成人精品| 国产欧美综合一区二区三区| 99精品视频精品精品视频| 日本精品国产| 国产精品精品国产一区二区| 男人的天堂久久精品| 国内在线观看一区二区三区| 免费日本视频一区| 黄在线观看免费网站ktv| 中文字幕亚洲在线观看| 日韩精品不卡一区二区| 日韩av一区二| 在线视频亚洲| 久久影院午夜精品| 国产日韩欧美在线播放不卡| 欧美日韩视频一区二区三区| 欧美激情网址| 中文无码久久精品| 99久久久久久中文字幕一区| 日本色综合中文字幕| 99久久九九| 国内精品美女在线观看| 偷拍亚洲精品| 欧美另类专区| 日产精品一区| 久久久91麻豆精品国产一区| 中文字幕一区二区精品区| 欧洲一级精品| 久久影视三级福利片| 一区二区精品| 亚洲精品一区二区在线看| 国产成人精品亚洲线观看| 亚洲精品无播放器在线播放| 蜜桃国内精品久久久久软件9| 美女视频网站久久| 日本一区福利在线| 日韩一级欧洲| 久久精品中文| 日韩大片在线播放| 精品伊人久久| 国产精品夜夜夜| 亚洲精品乱码久久久久久蜜桃麻豆 | 亚洲精品va| 日韩在线精品| 久久久久亚洲精品中文字幕| 日韩极品在线观看| 中文日韩欧美| 好吊日精品视频| 91精品福利| 99久精品视频在线观看视频| 亚洲午夜天堂| 黑人精品一区| 国产在线观看www| 国产成人免费av一区二区午夜| 国产精品久久久久久av公交车| 日本精品一区二区三区在线观看视频| 99热精品在线观看| 偷拍欧美精品| 狠狠爱www人成狠狠爱综合网| 亚洲二区免费| 2023国产精品久久久精品双| 日韩欧美一区二区三区在线视频| 国产乱码午夜在线视频| 日本久久精品| 日韩电影免费在线观看| 国语精品一区| 四虎成人av| 黄色在线网站噜噜噜| 免费看av不卡| 亚洲1234区| 国产99精品| 欧美粗暴jizz性欧美20| 激情五月综合| 麻豆成人在线| 婷婷综合国产| 国产精品最新| 国产精品一在线观看| 国产欧美久久一区二区三区| 国产精品久久久久77777丨| 国产精品多人| 四季av一区二区凹凸精品| 黄色在线观看www| 成人日韩在线观看| 亚洲免费高清| 亚洲精品字幕| 国产免费播放一区二区| 美腿丝袜亚洲三区| 日韩欧美在线中字| 欧美在线亚洲| 日本亚州欧洲精品不卡| 国产剧情在线观看一区| 国产精品.xx视频.xxtv| 国产一区二区三区不卡av| 日韩精品一卡| 亚洲一区欧美二区| 日本欧美韩国一区三区| 激情不卡一区二区三区视频在线| 欧洲亚洲一区二区三区| 麻豆精品91| 国产日产一区| 日韩中文在线电影| 欧美专区在线| 国产精品毛片aⅴ一区二区三区| 精品国产黄a∨片高清在线| 久久久一二三| 午夜在线播放视频欧美| 日本一不卡视频| 福利片在线一区二区| 不卡在线一区二区| 日韩专区视频网站| 国产精品久久久久久久免费观看 | 婷婷亚洲精品| 精品视频网站| 午夜日韩在线| 欧美一级全黄| 日韩欧美1区| 免费日韩av片| 国产中文欧美日韩在线| 亚洲欧美综合| 欧美日韩中文| 国产综合婷婷| 日韩精品一区二区三区免费视频| 国产91在线精品| 日本 国产 欧美色综合| 精品免费av| 玖玖精品视频| 成人亚洲一区| 亚洲欧美一级| 丝袜av一区| 久久精品凹凸全集| 免费精品国产的网站免费观看| 久久国产尿小便嘘嘘| 人人香蕉久久| 欧美亚洲三区| 亚州av乱码久久精品蜜桃| 国产精久久久| 丝袜亚洲另类欧美| 国产精品蜜芽在线观看| 综合激情婷婷| 久久精品不卡| 国产精品xxx在线观看| 日韩一区二区久久| 国产传媒在线| 欧美综合精品| 亚洲免费黄色| 日韩美女一区二区三区在线观看| 四虎成人精品一区二区免费网站 |