0

0

Java集合框架中的Stack与Queue类

P粉602998670

P粉602998670

发布时间:2026-01-08 14:19:02

|

852人浏览过

|

来源于php中文网

原创

应避免使用 java.util.Stack,改用 ArrayDeque 或 LinkedList 实现栈;Queue 是接口,需选用合适实现类;优先使用 offer()/poll()/peek() 而非 add()/remove()/element();迭代器不保证 LIFO/FIFO 顺序。

java集合框架中的stack与queue类

Stack 是遗留类,别用 java.util.Stack

Java 的 Stack 类继承自 Vector,底层用同步方法实现线程安全,但代价是性能差、设计过时。它违背了“组合优于继承”的原则——Stack 并不是一种特殊的 Vector,却强行继承,导致暴露了不该有的 add()removeAt() 等列表操作方法。

实际开发中应改用 Deque 接口的实现类:

  • ArrayDeque:非线程安全,性能最好,推荐作为使用(push()/pop()/peek()
  • LinkedList:也可用作栈,但因双向链表结构,随机访问慢,仅在需频繁首尾插入/删除且已引入该类时考虑
  • 如需线程安全,用 ConcurrentLinkedDeque 或外加 Collections.synchronizedDeque(),而非 Stack

Queue 接口才是标准队列抽象,实现类分工明确

Queue 是接口,不提供具体实现;真正可用的是它的实现类,各自适用场景差异很大:

  • LinkedList:实现了 Queue,支持 offer()/poll()/peek(),适合中小规模、非高并发场景
  • ArrayDeque:基于循环数组,无扩容锁争用,比 LinkedList 更快,且内存更紧凑,是多数情况下的首选
  • PriorityQueue:基于堆,元素按自然序或 Comparator 排序,poll() 返回最小(或自定义优先级最高)元素,不保证 FIFO
  • ConcurrentLinkedQueue无锁、线程安全、非阻塞,适合高并发生产者-消费者模型
  • LinkedBlockingQueue:可选有界/无界,阻塞式,put()/take() 会挂起线程,适合需要流控的场景

别混淆 add()offer() 的失败行为

这是初学者最常踩的坑:Queue 接口定义了两套添加方法,语义完全不同:

立即学习Java免费学习笔记(深入)”;

  • add(E):成功返回 true,失败(如队列满)抛出 IllegalStateException
  • offer(E):成功返回 true,失败(如容量限制或资源不足)返回 false,不抛异常

例如向有界队列 new ArrayBlockingQueue(2) 添加第 3 个元素:

Queue q = new ArrayBlockingQueue<>(2);
q.add("a"); // OK
q.add("b"); // OK
q.add("c"); // 抛出 IllegalStateException: Queue full

而换成 offer() 就不会崩溃:

恒浪威购商城
恒浪威购商城

基于asp.net2.0框架技术与企业级分布式框架以及与 ms sql server 2000数据库无缝集合而成,并且融合当前流行的ajax技术进行编写的电子商务系统,她整合了多用户商城、单用户商城功能和恒浪网站整合管理系统,吸收绝大部分同类产品的精华和优点,独创网络团购(b2t)电子商务模式,流程化的团购功能和视频导购等功能,是一款极具商业价值的电子商务系统。商城前台功能概述:商城会员可前台自行

下载
boolean success = q.offer("c"); // 返回 false,程序继续运行

除非你明确希望失败即中断流程,否则一律优先用 offer()poll()peek() 这组方法。

Stack 与 Queue 的迭代器都不反映 LIFO/FIFO 顺序

无论你用 ArrayDeque 当栈还是队列,调用 iterator() 得到的都是从头到尾的顺序遍历结果,不是后进先出,也不是严格按入队顺序(对 PriorityQueue 来说更不是)。

比如:

Deque stack = new ArrayDeque<>();
stack.push(1);
stack.push(2);
stack.push(3);
for (int i : stack) {
    System.out.print(i + " "); // 输出:3 2 1 —— 这是巧合,依赖于 ArrayDeque 内部结构
}

但注意:这并非规范保证。JDK 文档明确指出 ArrayDeque.iterator() “返回的迭代器不能保证以任何特定顺序遍历元素”。真实项目中若需按栈/队列逻辑遍历,应显式用 while (!stack.isEmpty()) stack.pop() 或收集后反转。

真正容易被忽略的是:没有“安全的、标准的、顺序确定的”遍历方式——必须根据用途手动控制弹出或复制快照。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

829

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

735

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

733

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

396

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16925

2023.08.03

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

3

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.4万人学习

C# 教程
C# 教程

共94课时 | 6.4万人学习

Java 教程
Java 教程

共578课时 | 44.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号