亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

java集合框架 arrayblockingqueue應用分析

2019-11-26 16:17:31
字體:
來源:轉載
供稿:網友
Queue
------------
1.ArrayDeque, (數組雙端隊列)
2.PriorityQueue, (優先級隊列)
3.ConcurrentLinkedQueue, (基于鏈表的并發隊列)
4.DelayQueue, (延期阻塞隊列)(阻塞隊列實現了BlockingQueue接口)
5.ArrayBlockingQueue, (基于數組的并發阻塞隊列)
6.LinkedBlockingQueue, (基于鏈表的FIFO阻塞隊列)
7.LinkedBlockingDeque, (基于鏈表的FIFO雙端阻塞隊列)
8.PriorityBlockingQueue, (帶優先級的無界阻塞隊列)
9.SynchronousQueue (并發同步阻塞隊列)
-----------------------------------------------------
ArrayBlockingQueue
是一個由數組支持的有界阻塞隊列。此隊列按 FIFO(先進先出)原則對元素進行排序。隊列的頭部 是在隊列中存在時間最長的元素。隊列的尾部 是在隊列中存在時間最短的元素。新元素插入到隊列的尾部,隊列獲取操作則是從隊列頭部開始獲得元素。
這是一個典型的“有界緩存區”,固定大小的數組在其中保持生產者插入的元素和使用者提取的元素。一旦創建了這樣的緩存區,就不能再增加其容量。試圖向已滿隊列中放入元素會導致操作受阻塞;試圖從空隊列中提取元素將導致類似阻塞。
此類支持對等待的生產者線程和消費者線程進行排序的可選公平策略。默認情況下,不保證是這種排序。然而,通過將公平性 (fairness) 設置為 true 而構造的隊列允許按照 FIFO 順序訪問線程。公平性通常會降低吞吐量,但也減少了可變性和避免了“不平衡性”。
復制代碼 代碼如下:

public class ArrayBlockingQueue<E> extends AbstractQueue<E> implements BlockingQueue<E>, java.io.Serializable {
/** 隊列元素 數組 */
private final E[] items;
/** 獲取、刪除元素時的索引(take, poll 或 remove操作) */
private int takeIndex;
/** 添加元素時的索引(put, offer或 add操作) */
private int putIndex;
/** 隊列元素的數目*/
private int count;
/** 鎖 */
private final ReentrantLock lock;
/** 獲取操作時的條件 */
private final Condition notEmpty;
/** 插入操作時的條件 */
private final Condition notFull;
//超出數組長度時,重設為0
final int inc(int i) {
return (++i == items.length)? 0 : i;
}
/**
* 插入元素(在獲得鎖的情況下才調用)
*/
private void insert(E x) {
items[putIndex] = x;
putIndex = inc(putIndex);
++count;
notEmpty.signal();
}
/**
* 獲取并移除元素(在獲得鎖的情況下才調用)
*/
private E extract() {
final E[] items = this.items;
E x = items[takeIndex];
items[takeIndex] = null;
takeIndex = inc(takeIndex);//移到下一個位置
--count;
notFull.signal();
return x;
}
/**
* 刪除i位置的元素
*/
void removeAt(int i) {
final E[] items = this.items;
// if removing front item, just advance
if (i == takeIndex) {
items[takeIndex] = null;
takeIndex = inc(takeIndex);
} else {
// 把i后面的直到putIndex的元素都向前移動一個位置
for (;;) {
int nexti = inc(i);
if (nexti != putIndex) {
items[i] = items[nexti];
i = nexti;
} else {
items[i] = null;
putIndex = i;
break;
}
}
}
--count;
notFull.signal();
}
/**
*構造方法,指定容量,默認策略(不是按照FIFO的順序訪問)
*/
public ArrayBlockingQueue(int capacity) {
this(capacity, false);
}
/**
*構造方法,指定容量及策略
*/
public ArrayBlockingQueue(int capacity, boolean fair) {
if (capacity <= 0)
throw new IllegalArgumentException();
this.items = (E[]) new Object[capacity];
lock = new ReentrantLock(fair);
notEmpty = lock.newCondition();
notFull = lock.newCondition();
}
/**
* 通過集合構造
*/
public ArrayBlockingQueue(int capacity, boolean fair,
Collection<? extends E> c) {
this(capacity, fair);
if (capacity < c.size())
throw new IllegalArgumentException();
for (Iterator<? extends E> it = c.iterator(); it.hasNext();)
add(it.next());
}
/**
* 插入元素到隊尾(super調用offer方法)
* public boolean add(E e) {
* if (offer(e))
* return true;
* else
* throw new IllegalStateException("Queue full");
* }
* 將指定的元素插入到此隊列的尾部(如果立即可行且不會超過該隊列的容量),
* 在成功時返回 true,如果此隊列已滿,則拋出 IllegalStateException。
*/
public boolean add(E e) {
return super.add(e);
}
/**
* 將指定的元素插入到此隊列的尾部(如果立即可行且不會超過該隊列的容量),
* 在成功時返回 true,如果此隊列已滿,則返回 false。
*/
public boolean offer(E e) {
if (e == null) throw new NullPointerException();
final ReentrantLock lock = this.lock;
lock.lock();
try {
if (count == items.length)
return false;
else {
insert(e);
return true;
}
} finally {
lock.unlock();
}
}
/**
* 將指定的元素插入此隊列的尾部,如果該隊列已滿,則等待可用的空間。
*/
public void put(E e) throws InterruptedException {
if (e == null) throw new NullPointerException();
final E[] items = this.items;
final ReentrantLock lock = this.lock;
lock.lockInterruptibly();
try {
try {
while (count == items.length)
notFull.await();
} catch (InterruptedException ie) {
notFull.signal(); // propagate to non-interrupted thread
throw ie;
}
insert(e);
} finally {
lock.unlock();
}
}
/**
* 將指定的元素插入此隊列的尾部,如果該隊列已滿,則在到達指定的等待時間之前等待可用的空間。
*/
public boolean offer(E e, long timeout, TimeUnit unit)
throws InterruptedException {
if (e == null) throw new NullPointerException();
long nanos = unit.toNanos(timeout);
final ReentrantLock lock = this.lock;
lock.lockInterruptibly();
try {
for (;;) {
if (count != items.length) {
insert(e);
return true;
}
if (nanos <= 0)//如果時間到了就返回
return false;
try {
nanos = notFull.awaitNanos(nanos);
} catch (InterruptedException ie) {
notFull.signal(); // propagate to non-interrupted thread
throw ie;
}
}
} finally {
lock.unlock();
}
}
//獲取并移除此隊列的頭,如果此隊列為空,則返回 null。
public E poll() {
final ReentrantLock lock = this.lock;
lock.lock();
try {
if (count == 0)
return null;
E x = extract();
return x;
} finally {
lock.unlock();
}
}
//獲取并移除此隊列的頭部,在元素變得可用之前一直等待(如果有必要)。
public E take() throws InterruptedException {
final ReentrantLock lock = this.lock;
lock.lockInterruptibly();
try {
try {
while (count == 0)
notEmpty.await();
} catch (InterruptedException ie) {
notEmpty.signal(); // propagate to non-interrupted thread
throw ie;
}
E x = extract();
return x;
} finally {
lock.unlock();
}
}
//獲取并移除此隊列的頭部,在指定的等待時間前等待可用的元素(如果有必要)。
public E poll(long timeout, TimeUnit unit) throws InterruptedException {
long nanos = unit.toNanos(timeout);
final ReentrantLock lock = this.lock;
lock.lockInterruptibly();
try {
for (;;) {
if (count != 0) {
E x = extract();
return x;
}
if (nanos <= 0)
return null;
try {
nanos = notEmpty.awaitNanos(nanos);
} catch (InterruptedException ie) {
notEmpty.signal(); // propagate to non-interrupted thread
throw ie;
}
}
} finally {
lock.unlock();
}
}
//獲取但不移除此隊列的頭;如果此隊列為空,則返回 null。
public E peek() {
final ReentrantLock lock = this.lock;
lock.lock();
try {
return (count == 0) ? null : items[takeIndex];
} finally {
lock.unlock();
}
}
/**
* 返回此隊列中元素的數量。
*/
public int size() {
final ReentrantLock lock = this.lock;
lock.lock();
try {
return count;
} finally {
lock.unlock();
}
}
/**
*返回在無阻塞的理想情況下(不存在內存或資源約束)此隊列能接受的其他元素數量。
*/
public int remainingCapacity() {
final ReentrantLock lock = this.lock;
lock.lock();
try {
return items.length - count;
} finally {
lock.unlock();
}
}
/**
* 從此隊列中移除指定元素的單個實例(如果存在)。
*/
public boolean remove(Object o) {
if (o == null) return false;
final E[] items = this.items;
final ReentrantLock lock = this.lock;
lock.lock();
try {
int i = takeIndex;
int k = 0;
for (;;) {
if (k++ >= count)
return false;
if (o.equals(items[i])) {
removeAt(i);
return true;
}
i = inc(i);
}
} finally {
lock.unlock();
}
}
/**
* 如果此隊列包含指定的元素,則返回 true。
*/
public boolean contains(Object o) {
if (o == null) return false;
final E[] items = this.items;
final ReentrantLock lock = this.lock;
lock.lock();
try {
int i = takeIndex;
int k = 0;
while (k++ < count) {
if (o.equals(items[i]))
return true;
i = inc(i);
}
return false;
} finally {
lock.unlock();
}
}
……
}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧亚精品在线观看| 日本午夜精品理论片a级appf发布| 欧美国产精品人人做人人爱| 日韩精品高清视频| 91麻豆桃色免费看| 日韩av电影免费观看高清| 欧美午夜丰满在线18影院| 亚洲福利视频久久| 日韩中文字幕网址| 久久久999国产| 7777kkkk成人观看| 久久天天躁狠狠躁夜夜爽蜜月| 尤物yw午夜国产精品视频| 国产一区二区香蕉| 欧美成人激情在线| 国产不卡一区二区在线播放| 亚洲色图13p| 亚洲美女www午夜| 国产精品日韩精品| 亚洲欧美福利视频| 2025国产精品视频| 国产成人亚洲综合青青| 97国产在线观看| 中文字幕亚洲一区二区三区| 亚洲国模精品一区| 欧美亚洲国产精品| 亚洲视频精品在线| 国产精品自产拍高潮在线观看| 九九久久久久99精品| 久久av资源网站| 久久精品久久久久电影| 欧美成人黑人xx视频免费观看| 国产精品久久久久不卡| 欧美大片免费观看在线观看网站推荐| 亚洲综合中文字幕在线观看| 亚洲色图欧美制服丝袜另类第一页| 亚洲最新av在线网站| 97福利一区二区| 亚洲资源在线看| 久久精品电影网站| 亚洲qvod图片区电影| 国产在线精品自拍| 韩国一区二区电影| 91国产一区在线| 欧美日韩中文字幕在线| 国产一区二区av| 免费91麻豆精品国产自产在线观看| 一区二区三区视频免费| 欧美一级片久久久久久久| 日日摸夜夜添一区| 日韩成人中文字幕| 国产一区玩具在线观看| 亚洲香蕉av在线一区二区三区| 欧美久久久精品| 久久国产精彩视频| 91中文字幕在线观看| 国产91九色视频| 日韩美女在线看| 亚洲一区二区三区毛片| 成人福利网站在线观看| 欧美精品日韩三级| 国产精品久久久久久久久久ktv| 亚洲精品国产精品国自产观看浪潮| 91免费视频网站| 国产一区二区免费| 45www国产精品网站| 亚洲精品资源美女情侣酒店| 亚洲成年人影院在线| 国产一区二区三区视频在线观看| 成人高清视频观看www| 中文字幕日韩av综合精品| 51久久精品夜色国产麻豆| 亚洲激情电影中文字幕| 久操成人在线视频| 精品亚洲一区二区| 久久久噜噜噜久噜久久| 亚洲视频综合网| 91情侣偷在线精品国产| 国产精品日韩av| 久久激情视频久久| 欧美一区二粉嫩精品国产一线天| 国产精品视频白浆免费视频| 国产精品久久久久久久av电影| 成人性教育视频在线观看| 亚洲视频在线观看免费| 亚洲精品第一页| 91久久国产婷婷一区二区| 精品成人在线视频| 欧美黄色小视频| 久久99热精品这里久久精品| 国产精品一区久久久| 欧美性猛交xxxx免费看漫画| 国产日韩欧美日韩大片| 这里只有精品在线观看| 国产性色av一区二区| 中文字幕在线看视频国产欧美| 色综合天天狠天天透天天伊人| 一本色道久久88精品综合| 久久久久久中文字幕| 亚洲女在线观看| 国产一区二区日韩| 国产一区二区视频在线观看| 91国偷自产一区二区三区的观看方式| 亚洲新声在线观看| 欧美激情一二区| 91av免费观看91av精品在线| 中文字幕成人在线| 日韩三级成人av网| 国产精品揄拍500视频| 亚洲a在线观看| 国产精品女人久久久久久| 91精品国产高清| 992tv在线成人免费观看| 欧美激情二区三区| 欧美亚洲日本网站| 日韩精品视频在线观看网址| 国产视频在线观看一区二区| 国产欧美一区二区白浆黑人| 91网站在线看| 国产在线久久久| 性金发美女69hd大尺寸| 国外日韩电影在线观看| 亚洲人av在线影院| 欧美第一页在线| 中文字幕最新精品| 欧美日韩成人在线播放| 久久久久久久久亚洲| 中文在线资源观看视频网站免费不卡| 成人激情视频在线观看| 九九热在线精品视频| 亚洲2020天天堂在线观看| 丝袜一区二区三区| 97人人爽人人喊人人模波多| 日韩精品在线影院| 青青在线视频一区二区三区| 国产精品啪视频| 亚洲男女自偷自拍图片另类| 国产在线观看91精品一区| 久久久精品一区| 欧美成人黑人xx视频免费观看| 日韩欧美在线视频观看| 亚洲综合中文字幕在线| 日韩av免费在线播放| 欧美日韩国产综合新一区| 国产男人精品视频| 国产成人精品999| 亚洲精品国产精品国产自| 国产成人精彩在线视频九色| 亚洲第一偷拍网| 国产成人+综合亚洲+天堂| 日韩美女在线观看一区| 亚洲自拍偷拍一区| 欧美激情国产日韩精品一区18| 亚洲最新av在线网站| 91精品国产91久久久久福利| 亚洲乱码av中文一区二区| 国产免费一区二区三区香蕉精| 久久伊人精品一区二区三区| 欧美老女人性视频| 91精品国产综合久久香蕉| 青青在线视频一区二区三区| 日韩在线视频免费观看| 中文日韩电影网站| 欧美大片免费观看|