java ArrayBlockingQueue的方法及缺點(diǎn)分析
提到ArrayBlockingQueue的方法,想必大家都不陌生,我們?cè)谌腙?duì)和出隊(duì)的時(shí)候,接觸了不少這方面的函數(shù)。當(dāng)然ArrayBlockingQueue中的方法也不止于此,今天我們就全部為大家羅列出來(lái),也算是做一個(gè)學(xué)習(xí)方向上的指引。然后就其中的peek方法帶來(lái)實(shí)例介紹,并說(shuō)明ArrayBlockingQueue使用的不足之處。
1.ArrayBlockingQueue函數(shù)列表
// 創(chuàng)建一個(gè)帶有給定的(固定)容量和默認(rèn)訪問(wèn)策略的 ArrayBlockingQueue。 ArrayBlockingQueue(int capacity) // 創(chuàng)建一個(gè)具有給定的(固定)容量和指定訪問(wèn)策略的 ArrayBlockingQueue。 ArrayBlockingQueue(int capacity, boolean fair) // 創(chuàng)建一個(gè)具有給定的(固定)容量和指定訪問(wèn)策略的 ArrayBlockingQueue,它最初包含給定 collection 的元素,并以 collection 迭代器的遍歷順序添加元素。 ArrayBlockingQueue(int capacity, boolean fair, Collection<? extends E> c) // 將指定的元素插入到此隊(duì)列的尾部(如果立即可行且不會(huì)超過(guò)該隊(duì)列的容量),在成功時(shí)返回 true,如果此隊(duì)列已滿,則拋出 IllegalStateException。 boolean add(E e) // 自動(dòng)移除此隊(duì)列中的所有元素。 void clear() // 如果此隊(duì)列包含指定的元素,則返回 true。 boolean contains(Object o) // 移除此隊(duì)列中所有可用的元素,并將它們添加到給定 collection 中。 int drainTo(Collection<? super E> c) // 最多從此隊(duì)列中移除給定數(shù)量的可用元素,并將這些元素添加到給定 collection 中。 int drainTo(Collection<? super E> c, int maxElements) // 返回在此隊(duì)列中的元素上按適當(dāng)順序進(jìn)行迭代的迭代器。 Iterator<E> iterator() // 將指定的元素插入到此隊(duì)列的尾部(如果立即可行且不會(huì)超過(guò)該隊(duì)列的容量),在成功時(shí)返回 true,如果此隊(duì)列已滿,則返回 false。 boolean offer(E e) // 將指定的元素插入此隊(duì)列的尾部,如果該隊(duì)列已滿,則在到達(dá)指定的等待時(shí)間之前等待可用的空間。 boolean offer(E e, long timeout, TimeUnit unit) // 獲取但不移除此隊(duì)列的頭;如果此隊(duì)列為空,則返回 null。 E peek() // 獲取并移除此隊(duì)列的頭,如果此隊(duì)列為空,則返回 null。 E poll() // 獲取并移除此隊(duì)列的頭部,在指定的等待時(shí)間前等待可用的元素(如果有必要)。 E poll(long timeout, TimeUnit unit) // 將指定的元素插入此隊(duì)列的尾部,如果該隊(duì)列已滿,則等待可用的空間。 void put(E e) // 返回在無(wú)阻塞的理想情況下(不存在內(nèi)存或資源約束)此隊(duì)列能接受的其他元素?cái)?shù)量。 int remainingCapacity() // 從此隊(duì)列中移除指定元素的單個(gè)實(shí)例(如果存在)。 boolean remove(Object o) // 返回此隊(duì)列中元素的數(shù)量。 int size() // 獲取并移除此隊(duì)列的頭部,在元素變得可用之前一直等待(如果有必要)。 E take() // 返回一個(gè)按適當(dāng)順序包含此隊(duì)列中所有元素的數(shù)組。 Object[] toArray() // 返回一個(gè)按適當(dāng)順序包含此隊(duì)列中所有元素的數(shù)組;返回?cái)?shù)組的運(yùn)行時(shí)類型是指定數(shù)組的運(yùn)行時(shí)類型。 <T> T[] toArray(T[] a) // 返回此 collection 的字符串表示形式。 String toString()
2.peek方法實(shí)例
讀取隊(duì)列中隊(duì)首的元素,不會(huì)刪除該元素。
//獲取元素,元素不出隊(duì)
public E peek() {
//上鎖
final ReentrantLock lock = this.lock;
lock.lock();
try {
//調(diào)用itemAt方法獲取元素
return itemAt(takeIndex); // null when queue is empty
} finally {
//釋放鎖資源
lock.unlock();
}
}
3.ArrayBlockingQueue缺點(diǎn)
(1)隊(duì)列長(zhǎng)度固定且必須在初始化時(shí)指定,所以使用之前一定要慎重考慮好容量;
(2)如果消費(fèi)速度跟不上入隊(duì)速度,則會(huì)導(dǎo)致提供者線程一直阻塞,且越阻塞越多,非常危險(xiǎn);
(3)只使用了一個(gè)鎖來(lái)控制入隊(duì)出隊(duì),效率較低
ArrayBlockingQueue用法擴(kuò)展:
1、ArrayBlockingQueue(int)
接收一個(gè)整型的參數(shù),這個(gè)整型參數(shù)指的是隊(duì)列的長(zhǎng)度,其定義如下,
public ArrayBlockingQueue(int capacity) {
this(capacity, false);
}
可以看到這個(gè)方法調(diào)用的是ArrayBlockingQueue(int,boolean)方法,那么看下這個(gè)方法,
2、ArrayBlockingQueue(int,boolean)
接收兩個(gè)參數(shù),一個(gè)整型,一個(gè)boolean類型,前邊已經(jīng)知道整型參數(shù)是隊(duì)列的長(zhǎng)度,那么boolean類型參數(shù)代表什么意思那,其定義如下,
public ArrayBlockingQueue(int capacity, boolean fair) {
if (capacity <= 0)
throw new IllegalArgumentException();
this.items = new Object[capacity];
lock = new ReentrantLock(fair);
notEmpty = lock.newCondition();
notFull = lock.newCondition();
}
可以看到在這個(gè)構(gòu)造方法中進(jìn)行了相關(guān)邏輯實(shí)現(xiàn),對(duì)items進(jìn)行了數(shù)組初始化,boolean類型的參數(shù)是作為可重入鎖的參數(shù)進(jìn)行初始化,規(guī)定可重入鎖是公平還是不公平,默認(rèn)為false,另外初始化了notEmpty、notFull兩個(gè)信號(hào)量。
到此這篇關(guān)于java ArrayBlockingQueue的方法及缺點(diǎn)分析的文章就介紹到這了,更多相關(guān)java ArrayBlockingQueue的方法及不足點(diǎn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- java ArrayBlockingQueue阻塞隊(duì)列的實(shí)現(xiàn)示例
- Java中ArrayBlockingQueue和LinkedBlockingQueue
- Java 并發(fā)編程ArrayBlockingQueue的實(shí)現(xiàn)
- Java源碼解析阻塞隊(duì)列ArrayBlockingQueue介紹
- Java源碼解析阻塞隊(duì)列ArrayBlockingQueue常用方法
- Java源碼解析阻塞隊(duì)列ArrayBlockingQueue功能簡(jiǎn)介
- 詳細(xì)分析Java并發(fā)集合ArrayBlockingQueue的用法
- java并發(fā)之ArrayBlockingQueue詳細(xì)介紹
- Java并發(fā)編程ArrayBlockingQueue的使用
相關(guān)文章
Spring中@RabbitHandler和@RabbitListener的區(qū)別詳析
@RabbitHandler是用于處理消息的方法注解,它與@RabbitListener注解一起使用,這篇文章主要給大家介紹了關(guān)于Spring中@RabbitHandler和@RabbitListener區(qū)別的相關(guān)資料,需要的朋友可以參考下2024-02-02
Java String方法獲取字符出現(xiàn)次數(shù)及字符最大相同部分示例
這篇文章主要介紹了Java String方法獲取字符出現(xiàn)次數(shù)及字符最大相同部分,涉及java字符串的遍歷、比較、計(jì)算等相關(guān)操作技巧,需要的朋友可以參考下2017-09-09
idea創(chuàng)建springboot項(xiàng)目,Application.java不能運(yùn)行問(wèn)題及解決
這篇文章主要介紹了idea創(chuàng)建springboot項(xiàng)目,Application.java不能運(yùn)行問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11
SpringBoot常用注解@RestControllerAdvice詳解
這篇文章主要介紹了SpringBoot常用注解@RestControllerAdvice詳解,@RestControllerAdvice是一個(gè)組合注解,由@ControllerAdvice、@ResponseBody組成,而@ControllerAdvice繼承了@Component,因此@RestControllerAdvice本質(zhì)上是個(gè)Component,需要的朋友可以參考下2024-01-01
eclipse+jdk安裝以及會(huì)遇到的問(wèn)題及解決方法
這篇文章主要介紹了eclipse+jdk安裝以及會(huì)遇到的問(wèn)題+解決方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10
Springboot項(xiàng)目編譯后未能加載靜態(tài)資源文件的問(wèn)題
這篇文章主要介紹了Springboot項(xiàng)目編譯后未能加載靜態(tài)資源文件的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
Java8中Lambda表達(dá)式使用和Stream API詳解
這篇文章主要給大家介紹了關(guān)于Java8中Lambda表達(dá)式使用和Stream API的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Java8具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05

