博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java容器深入浅出之PriorityQueue、ArrayDeque和LinkedList
阅读量:6211 次
发布时间:2019-06-21

本文共 2378 字,大约阅读时间需要 7 分钟。

Queue用于模拟一种FIFO(first in first out)的队列结构。一般来说,典型的队列结构不允许随机访问队列中的元素。队列包含的方法为:

1. 入队

void add(Object o): 指定元素加入队列尾部

boolean offer(Object o):同上,在有限容量队列中,此方法更好

2. 出队

Object poll():获取头部元素,并从队列中删除;如果队列为空,则返回null

Object remove():获取头部元素,并从队列中删除;

3. 出队不删除

Object peek():获取头部元素,不删除;如果队列为空,则返回null

Object element():获取头部元素,不删除;

PriorityQueue

PriorityQueue是Queue接口的实现类,但是它并不是一个FIFO的队列实现,具体表现在:

1. 保存顺序与FIFO无关,而是按照元素大小进行重排序;因此poll出来的是按照有小到大来取。

2. 不允许保存null,排序规则有自然排序和定制排序两种,规则与TreeSet一致。

Deque接口与ArrayDeque实现类

Deque实现的是一个双端队列,因此它具有“FIFO队列”及“栈”的方法特性,其中ArrayDeque是其典型的实现类。

1. ArrayDeque的栈实现

1 public class ArrayDequeStack { 2  3     public static void main(String[] args) { 4         ArrayDeque
stack = new ArrayDeque<>(); 5 //压栈,此时AAA在最下,CCC在最外 6 stack.push("AAA"); 7 stack.push("BBB"); 8 stack.push("CCC"); 9 System.out.println(stack);10 //获取最后添加的元素,但不删除11 System.out.println(stack.peek());12 System.out.println(stack);13 //弹出最后添加的元素14 System.out.println(stack.pop());15 System.out.println(stack);16 }17 18 }

2. ArrayDeque的FIFO队列实现

1 public class ArrayDequeQueue { 2  3     public static void main(String[] args) { 4         ArrayDeque
queue = new ArrayDeque<>(); 5 //入队 6 queue.offer("AAA"); 7 queue.offer("BBB"); 8 queue.offer("CCC"); 9 System.out.println(queue);10 //获取但不出队11 System.out.println(queue.peek());12 System.out.println(queue);13 //出队14 System.out.println(queue.poll());15 System.out.println(queue);16 }17 18 }

LinkedList实现类

LinkedList比较特殊,它既实现了List接口,同时也实现了Deque接口。因此它具备了List、队列和栈的特性,在应用开发中有广泛的用途。

1 public class TestLinkedList { 2  3     public static void main(String[] args) { 4         LinkedList
ll = new LinkedList<>(); 5 //入队 6 ll.offer("AAA"); 7 //压栈 8 ll.push("BBB"); 9 //双端的另一端入队10 ll.addFirst("NNN");11 ll.forEach(str -> System.out.println("遍历中:" + str));12 //获取队头13 System.out.println(ll.peekFirst());14 //获取队尾15 System.out.println(ll.peekLast());16 //弹栈17 System.out.println(ll.pop());18 System.out.println(ll);19 //双端的后端出列20 System.out.println(ll.pollLast());21 System.out.println(ll);22 }23 }

转载地址:http://chdja.baihongyu.com/

你可能感兴趣的文章
Kali-linux Arpspoof工具
查看>>
PDF文档页面如何重新排版?
查看>>
基于http协议使用protobuf进行前后端交互
查看>>
bash腳本編程之三 条件判断及算数运算
查看>>
php cookie
查看>>
linux下redis安装
查看>>
弃 Java 而使用 Kotlin 的你后悔了吗?| kotlin将会是最好的开发语言
查看>>
JavaScript 数据类型
查看>>
量子通信和大数据最有市场突破前景
查看>>
StringBuilder用法小结
查看>>
对‘初学者应该选择哪种编程语言’的回答——计算机达人成长之路(38)
查看>>
如何申请开通微信多客服功能
查看>>
Sr_C++_Engineer_(LBS_Engine@Global Map Dept.)
查看>>
非监督学习算法:异常检测
查看>>
《OSPF和IS-IS详解》一2.7 BGP-IGP的路由交换
查看>>
App开发中甲乙方冲突会闹出啥后果?H5 APP 开发可以改变现状吗
查看>>
python知识点总结---函数
查看>>
jquery的checkbox,radio,select等方法总结
查看>>
Linux coredump
查看>>
Ubuntu 10.04安装水晶(Mercury)无线网卡驱动
查看>>