java基础:13.6 集合框架 - Queue(Deque)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/L20902/article/details/89005372

1、概述

Deque是Queue的子接口,我们知道Queue是一种队列形式,而Deque(double-ended queue)则是双向队列,它支持从两个端点方向检索和插入元素,因此Deque既可以支持LIFO形式也可以支持LIFO形式。

Deque接口是一种比Stack和Vector更为丰富的抽象数据形式,因为它同时实现了以上两者。

addFirst(e) 、removeFirst() 、addLast(e)、removeLast()、getFirst()、getLast()都在Deque 接口中定义。

2、主要方法

在这里插入图片描述

可以看出Deque在Queue的方法上新添了对队列头尾元素的操作,add,remove,get形式的方法会在有界队列满员和空队列时抛出异常,offer,poll,peek形式的方法则会返回false或null.

此外方法表中需要注意push = addFirst,pop = removeFirst,只是使用了不同的方法名体现队列表示栈结构时的特点.
 

3、实现

同Queue一样Deque的实现也可以划分成通用实现和并发实现.

通用实现主要有两个实现类ArrayDeque和LinkedList.

ArrayDeque是个可变数组,它是在Java 6之后新添加的,而LinkedList是一种链表结构的list.LinkedList要比ArrayDeque更加灵活,因为它也实现了List接口的所有操作,并且可以插入null元素,这在ArrayDeque中是不允许的.

从效率来看,ArrayDeque要比LinkedList在两端增删元素上更为高效,因为没有在节点创建删除上的开销.最适合使用LinkedList的情况是迭代队列时删除当前迭代的元素.此外LinkedList可能是在遍历元素时最差的数据结构,并且也LinkedList占用更多的内存,因为LinkedList是通过链表连接其整个队列,它的元素在内存中是随机分布的,需要通过每个节点包含的前后节点的内存地址去访问前后元素.

总体ArrayDeque要比LinkedList更优越,在大队列的测试上有3倍与LinkedList的性能,最好的是给ArrayDeque一个较大的初始化大小,以避免底层数组扩容时数据拷贝的开销.

扫描二维码关注公众号,回复: 6399835 查看本文章

LinkedBlockingDeque是Deque的并发实现,在队列为空的时候,它的takeFirst,takeLast会阻塞等待队列处于可用状态

猜你喜欢

转载自blog.csdn.net/L20902/article/details/89005372