news 2026/5/16 23:44:32

java基础-ArrayDeque

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
java基础-ArrayDeque

ArrayDequeJava 集合框架中的一个类,它是一个基于可调整大小的循环数组实现的双端队列

是Deque接口的实现类之一

继承关系:

Iterable (接口) ↓ Collection (接口) ↓ Queue (接口) ↓ Deque (接口) ↓ ┌─────────────────┐ │ ArrayDeque (类) │ ← 具体实现 └─────────────────┘

主要特点:

1.数据结构

  • 底层使用动态数组(循环数组)实现

  • 允许从两端高效地添加/移除元素

  • 内存连续,访问速度快

2.核心特性

  • 线程不安全(非同步)

  • 不允许存储 null 元素

  • 初始容量默认为16,自动扩容(2倍)

  • 既可作为栈(Stack)使用,也可作为队列(Queue)使用

  • 性能通常优于 LinkedList(作为队列/栈时)

常用方法:

队列操作(FIFO)

ArrayDeque<String> deque = new ArrayDeque<>(); // 添加元素到队尾 deque.offer("A"); // 推荐 deque.add("B"); // 可能抛出异常 deque.offerLast("C"); // 明确指定队尾 // 从队首移除并返回 String first = deque.poll(); // 返回null如果为空 String first2 = deque.remove(); // 抛出异常如果为空 String first3 = deque.pollFirst(); // 查看队首(不移除) String peek = deque.peek(); String peek2 = deque.peekFirst();

栈操作(LIFO)

// 作为栈使用 ArrayDeque<String> stack = new ArrayDeque<>(); // 压栈 stack.push("A"); // 添加到队首 stack.addFirst("B"); // 弹栈 String top = stack.pop(); // 移除队首 String top2 = stack.pollFirst(); // 查看栈顶 String peek = stack.peek(); String peek2 = stack.peekFirst();

双端队列操作

// 队首操作 deque.addFirst("First"); deque.offerFirst("First"); deque.removeFirst(); deque.pollFirst(); // 队尾操作 deque.addLast("Last"); deque.offerLast("Last"); deque.removeLast(); deque.pollLast();

性能对比

操作ArrayDequeLinkedList
添加/删除(两端)O(1)*O(1)
随机访问O(1)O(n)
内存使用更紧凑更多(节点开销)
遍历速度更快(缓存友好)较慢

注意:ArrayDeque的O(1)是分摊时间复杂度,扩容时会有额外开销

使用场景推荐:

推荐使用 ArrayDeque:

  1. 作为栈使用(替代过时的 Stack 类)

    // 推荐 Deque<Integer> stack = new ArrayDeque<>(); // 不推荐(已过时) Stack<Integer> oldStack = new Stack<>();
  2. 作为队列使用

    Queue<String> queue = new ArrayDeque<>();
  3. 需要高效的双端操作

    Deque<Integer> deque = new ArrayDeque<>();

不适合的场景:

  1. 需要线程安全(考虑使用 ConcurrentLinkedDeque)

  2. 需要存储 null 元素

  3. 需要频繁在中间插入/删除

示例代码:

public class ArrayDequeExample { public static void main(String[] args) { // 1. 作为队列 Queue<Integer> queue = new ArrayDeque<>(); queue.offer(1); queue.offer(2); System.out.println(queue.poll()); // 1 // 2. 作为栈 Deque<Integer> stack = new ArrayDeque<>(); stack.push(1); stack.push(2); System.out.println(stack.pop()); // 2 // 3. 作为双端队列 ArrayDeque<String> deque = new ArrayDeque<>(); deque.addFirst("First"); deque.addLast("Last"); System.out.println(deque); // [First, Last] } }

注意事项:

  1. 线程安全:ArrayDeque 不是线程安全的,多线程环境下需要外部同步

  2. 容量限制:最大容量是Integer.MAX_VALUE - 8

  3. 迭代器:迭代器是 fail-fast 的

  4. 性能:在大多数场景下,作为栈/队列使用时性能优于 LinkedList

总结:ArrayDeque 是 Java 中实现队列和栈的首选类,它提供了高效的性能、简洁的API,并且比传统的Stack类更现代、更安全。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/11 20:25:06

如何快速掌握汉字书写:MakeMeAHanzi 免费开源项目完整指南

如何快速掌握汉字书写&#xff1a;MakeMeAHanzi 免费开源项目完整指南 【免费下载链接】makemeahanzi Free, open-source Chinese character data 项目地址: https://gitcode.com/gh_mirrors/ma/makemeahanzi MakeMeAHanzi 是一个强大的免费开源汉字数据库项目&#xff…

作者头像 李华
网站建设 2026/5/8 1:39:41

Java内部类:全面解析与实践指南

内部类的基本概念 内部类&#xff08;Inner Class&#xff09;是定义在另一个类内部的类&#xff0c;能够访问外部类的成员&#xff08;包括私有成员&#xff09;。根据定义方式和作用域&#xff0c;内部类可分为成员内部类、局部内部类、匿名内部类和静态内部类。 成员内部类…

作者头像 李华
网站建设 2026/5/15 13:51:56

2026元旦放假通知

放假时间​2026 年 1 月 1 日&#xff08;星期四&#xff09;—2026 年 1 月 3 日&#xff08;星期六&#xff09;共 3 天&#xff0c;2026 年 1 月 4 日&#xff08;星期日&#xff09;正常返岗办公。​温馨提示​请各部门提前做好工作安排&#xff0c;确保节前各项事务妥善处…

作者头像 李华
网站建设 2026/5/14 2:26:32

Web开发者快速上手AI Agent:基于提示工程的旅游攻略系统实战

图片来源网络&#xff0c;侵权联系删。 文章目录引言&#xff1a;从Web需求优化到AI提示词优化Web开发与AI Agent应用的天然衔接点Agent提示词优化的核心原理&#xff08;Web视角解读&#xff09;1. 提示词 前端组件的Props2. Agent的“思维链” 后端业务逻辑流程实战&#x…

作者头像 李华
网站建设 2026/4/29 4:21:23

Web开发者进阶AI Agent:基于LlamaIndex构建企业级RAG Pipeline实战

图片来源网络&#xff0c;侵权联系删。 文章目录 1. 前言2. Loading解析&#xff1a;从原始文件到结构化节点&#xff08;Documents & Nodes&#xff09;2.1 Documents 原始数据记录&#xff08;类比数据库表行&#xff09;2.2 Node解析器 数据清洗与切片&#xff08;类比…

作者头像 李华
网站建设 2026/5/4 19:22:33

OpenPI:打造智能机器人决策系统的完整指南

OpenPI&#xff1a;打造智能机器人决策系统的完整指南 【免费下载链接】openpi 项目地址: https://gitcode.com/GitHub_Trending/op/openpi 你想知道如何快速构建一个强大的机器人智能决策系统吗&#xff1f;OpenPI项目正是你需要的解决方案&#xff01;这个开源项目提…

作者头像 李华