Deque双端队列

1)阻塞双端队列BlockingDeque

BlockingDeque类是一个双端队列,在不能够插入元素时,它将阻塞住试图插入元素的线程;
在不能够抽取元素时,它将阻塞住试图抽取的线程.deque
(双端队列)是“Double结束队列”的缩写。因此,端的双队列的英文一个你可以从任意一
端的插入或者抽取元素的队列。

BlockingDeque 的使用

在线程既是一个队列的生产者又是这个队列的消费者的时候可以使用到 BlockingDeque。如
果生产者线程需要在队列的两端都可以插入数据,消费者线程需要在队列的两端都可以移除
数据,这个时候也可以使用 BlockingDeque。

一个线程生产元素,并把它们插入到队列的任意一端。如果双端队列已满,插入线程将被阻
塞,直到一个移除线程从该队列中移出了一个元素。如果双端队列为空,移除线程将被阻塞,
直到一个插入线程向该队列插入了一个新元素。

BlockingDeque 的方法

BlockingDeque 具有 4 组不同的方法用于插入、移除以及对双端队列中的元素进行检查。
如果请求的操作不能得到立即执行的话,每个方法的表现也不同。这些方法如下:

四组不同的行为方式解释:

1. 抛异常:如果试图的操作无法立即执行,抛一个异常。

2. 特定值:如果试图的操作无法立即执行,返回一个特定的值(常常是 true / false)。

3. 阻塞:如果试图的操作无法立即执行,该方法调用将会发生阻塞,直到能够执行。

4. 超时:如果试图的操作无法立即执行,该方法调用将会发生阻塞,直到能够执行,但等待时间不会超过给定值。返回一个特定值以告知该操作是否成功(典型的是 true / false)。
 

BlockingDeque 代码实例

以下是如何使用 BlockingDeque 方法的一个简短代码示例:
BlockingDeque<String> deque = new LinkedBlockingDeque<String>();
deque.addFirst("1");
deque.addLast("2");
String two = deque.takeLast();
String one = deque.takeLast();

2)链阻塞双端队列 LinkedBlockingDeque

LinkedBlockingDeque 类实现了 BlockingDeque 接口。
deque(双端队列) 是 "Double Ended Queue" 的缩写。因此,双端队列是一个你可以从任意一
端插入或者抽取元素的队列。(译者注:唐僧啊,受不了。)
LinkedBlockingDeque 是一个双端队列,在它为空的时候,一个试图从中抽取数据的线程将
会阻塞,无论该线程是试图从哪一端抽取数据。
以下是 LinkedBlockingDeque 实例化以及使用的示例:
BlockingDeque<String> deque = new LinkedBlockingDeque<String>();
deque.addFirst("1");
deque.addLast("2");
String two = deque.takeLast();
String one = deque.takeFirst();

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值