Java容器深入浅出之PriorityQueue、ArrayDeque和LinkedList

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: Queue用于模拟一种FIFO(first in first out)的队列结构。一般来说,典型的队列结构不允许随机访问队列中的元素。队列包含的方法为:1. 入队void add(Object o): 指定元素加入队列尾部boolean offer(Object o):同上,在有限容量队列中,此方法更好2.

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<String> 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<String> 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<String> 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 }
目录
相关文章
|
12天前
|
Kubernetes Cloud Native Java
云原生之旅:从容器到微服务的演进之路Java 内存管理:垃圾收集器与性能调优
【8月更文挑战第30天】在数字化时代的浪潮中,企业如何乘风破浪?云原生技术提供了一个强有力的桨。本文将带你从容器技术的基石出发,探索微服务架构的奥秘,最终实现在云端自由翱翔的梦想。我们将一起见证代码如何转化为业务的翅膀,让你的应用在云海中高飞。
|
22天前
|
存储 Java 索引
【Java集合类面试二十四】、ArrayList和LinkedList有什么区别?
ArrayList基于动态数组实现,支持快速随机访问;LinkedList基于双向链表实现,插入和删除操作更高效,但占用更多内存。
|
19天前
|
Java Linux Maven
java依赖冲突解决问题之容器加载依赖jar包如何解决
java依赖冲突解决问题之容器加载依赖jar包如何解决
|
19天前
|
存储 消息中间件 Java
何时在 Java 中使用 ArrayList 和 LinkedList
【8月更文挑战第23天】
10 2
|
20天前
|
存储 Java
|
20天前
|
存储 Java 索引
Java 中 ArrayList 和 LinkedList 之间的区别
【8月更文挑战第22天】
49 1
|
22天前
|
安全 算法 Java
【Java集合类面试二】、 Java中的容器,线程安全和线程不安全的分别有哪些?
这篇文章讨论了Java集合类的线程安全性,列举了线程不安全的集合类(如HashSet、ArrayList、HashMap)和线程安全的集合类(如Vector、Hashtable),同时介绍了Java 5之后提供的java.util.concurrent包中的高效并发集合类,如ConcurrentHashMap和CopyOnWriteArrayList。
【Java集合类面试二】、 Java中的容器,线程安全和线程不安全的分别有哪些?
|
22天前
|
Java 容器
【Java集合类面试一】、 Java中有哪些容器(集合类)?
这篇文章列出了Java中的四大类集合接口:Set、List、Queue和Map,以及它们的常用实现类,如HashSet、TreeSet、ArrayList、LinkedList、ArrayDeque、HashMap和TreeMap。
【Java集合类面试一】、 Java中有哪些容器(集合类)?
|
13天前
|
存储 安全 Java
java基础Java的Deque之Deque、BlockingDeque、LinkedBlockingDeque、ArrayDeque
在实际编程中,合理利用Java的Deque和它的具体实现,可以在不同的应用场景中发挥高效和线程安全的队列管理功能。通过了解和比较Deque的不同实现,可以根据应用需求做出适当的技术选型,以支持高效且健壮的应用架构。
8 0
|
20天前
|
存储 缓存 Java