java数据结构之Queue

43 篇文章 0 订阅
9 篇文章 0 订阅

                                     java数据结构之Queue

java的数据结构比较多,一个个说也没那么多时间,所以挑一些上层接口来集中说下,今天说说Queue这个接口。

Queue: 基本上,一个队列就是一个先入先出(FIFO)的数据结构

Queue接口与List、Set同一级别,都是继承了Collection接口。LinkedList实现了Deque接 口。

Queue接口定义了插入、检查、取出等方法,每种方法都有两种形式,一种就是失败时候抛出异常,另一种就是失败返回特定的值。

 Throws exceptionReturns special value
Insertadd(e)offer(e)
Removeremove()poll()
Examineelement()peek()

看下Queue的层次结构图

可以看到主要有三种,抽象类AbstractQueue、接口BlockingQueue、接口Deque。

具体的实现类比较多,主要分为阻塞和不阻塞的,阻塞队列内部主要通过锁来控制,如果操作不成功就等待。

BlockingQueue接口的方法主要包括四类,如下

 Throws exceptionSpecial valueBlocksTimes out
Insertadd(e)offer(e)put(e)offer(e, time, unit)
Removeremove()poll()take()poll(time, unit)
Examineelement()peek()  

 

看下ArrayBlockingQueue这个类,这是一个有界队列,队列容量固定的,适合生产者消费者模型。

ArrayBlockingQueue内部的阻塞实现是通过ReentrantLock和Condition来实现的。

其他的实现以后有空在介绍。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值