本篇文章給大家分享的是有關(guān)java中阻塞隊(duì)列的實(shí)現(xiàn)原理是什么,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。
創(chuàng)新互聯(lián)建站專業(yè)IDC數(shù)據(jù)服務(wù)器托管提供商,專業(yè)提供成都服務(wù)器托管,服務(wù)器租用,資陽(yáng)托管服務(wù)器,資陽(yáng)托管服務(wù)器,成都多線服務(wù)器托管等服務(wù)器托管服務(wù)。
阻塞隊(duì)列與普通隊(duì)列的不同在于。當(dāng)隊(duì)列是空的時(shí)候,從隊(duì)列中獲取元素的操作將會(huì)被阻塞,或者當(dāng)隊(duì)列滿時(shí),往隊(duì)列里面添加元素將會(huì)被阻塞。試圖從空的阻塞隊(duì)列中獲取元素的線程將會(huì)被阻塞,直到其他的線程往空的隊(duì)列插入新的元素。同樣,試圖往已滿的阻塞隊(duì)列中添加新元素的線程同樣也會(huì)被阻塞,直到其他的線程使隊(duì)列重新變得空閑起來(lái),如從隊(duì)列中移除一個(gè)或者多個(gè)元素,或者完全清空隊(duì)列,下圖展示了如何通過(guò)阻塞隊(duì)列來(lái)合作:
線程1往阻塞隊(duì)列中添加元素,而線程2從阻塞隊(duì)列中移除元素
從5.0開(kāi)始,JDK在Java.util.concurrent包里提供了阻塞隊(duì)列的官方實(shí)現(xiàn)。盡管JDK中已經(jīng)包含了阻塞隊(duì)列的官方實(shí)現(xiàn)。
阻塞隊(duì)列的實(shí)現(xiàn)
阻塞隊(duì)列的實(shí)現(xiàn)類似于帶上限的Semaphore的實(shí)現(xiàn)。
廢話不多說(shuō):
package com.huojg.test; import java.util.LinkedList; import java.util.List; public class BlockingQueue { private List queue = new LinkedList(); private int limit = 10; public BlockingQueue(int limit){ this.limit = limit; } public synchronized void enqueue(Object item) throws InterruptedException { while(this.queue.size() == this.limit) { wait(); } if(this.queue.size() == 0) { notifyAll(); } this.queue.add(item); } public synchronized Object dequeue() throws InterruptedException{ while(this.queue.size() == 0){ wait(); } if(this.queue.size() == this.limit){ notifyAll(); } return this.queue.remove(0); } }
以上就是java中阻塞隊(duì)列的實(shí)現(xiàn)原理是什么,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。