Java集合框架之Stack Queue Deque使用详解刨析
作者:谢谢你,泰罗! 发布时间:2022-06-11 06:10:19
1. Stack
1.1 介绍
Stack 栈是 Vector 的一个子类,它实现了一个标准的后进先出的栈。它的底层是一个数组。
堆栈只定义了默认构造函数,用来创建一个空栈。堆栈除了包括由 Vector 定义的所有方法,也定义了自己的一些方法。
1.2 常见方法
方法 | 描述 |
---|---|
E push(E item) | 压栈 |
E pop() | 出栈 |
E peek() | 查看栈顶元素,不删除 |
boolean empty() | 判断栈是否为空 |
注意: 下面的示例都是一份代码分开拿出来的,上下其实是有逻辑关系的
示例一: 用 Stack 构造一个元素为整形的栈
Stack<Integer> stack = new Stack<>();
示例二: 压栈
stack.push(1);
stack.push(2);
stack.push(3);
// 结果为:[1, 2, 3]
示例三: 查看栈顶元素不删除
System.out.println(stack.peek());
System.out.println(stack);
// 结果为:3 和 [1, 2, 3]
示例四: 出栈
System.out.println(stack.pop());
System.out.println(stack);
// 结果为:3 和 [1, 2]
示例五: 判断栈是否为空
System.out.println(stack.empty());
// 结果为:false
2. Queue
2.1 介绍
Queue 队列是一种特殊的线性表,它只允许在表的前端进行删除操作,而在表的后端进行插入操作。
LinkedList 类实现了 Queue 接口,因此我们可以把 LinkedList 当成 Queue 来用。
2.2 常见方法
方法 | 描述 |
---|---|
boolean offer(E e) | 入队列(出现错误返回特殊值) |
boolean add(E e) | 入队列(出现错误抛异常) |
E poll() | 出队列(出现错误返回特殊值) |
E remove() | 出队列(出现错误抛异常) |
E peek() | 得到队首元素,不删除(出现错误返回特殊值) |
E element() | 得到队首元素,不删除(出现错误抛异常) |
boolean isEmpty() | 判断队列是否为空 |
注意: 接下来使用 LinkedList 演示队列的使用方法,只要把握先进先出的原则就行。下面的示例都是一份代码分开拿出来的,上下其实是有逻辑关系的
示例一: 使用 LinkedList 创建一个元素为整型的队列
LinkedList<Integer> linkedList = new LinkedList<>();
示例二: 入队列
linkedList.offer(1);
linkedList.offer(2);
linkedList.offer(3);
示例三: 出队列
System.out.println(linkedList.poll());
// 结果为:1
示例四: 得到队首元素,不删除
System.out.println(linkedList.peek());
// 结果为:2
示例五: 判断队列是否为空
System.out.println(linkedList.isEmpty());
// 结果为:false
3. Deque
3.1 介绍
双端队列是指允许两端都可以进行入队和出队操作的队列。元素可以从队头出队和入队,也可以从队尾出队和入队
LinkedList 类实现了 Deque 接口,因此我们可以把 LinkedList 当成 Deque 来用。
3.2 常见方法
方法 | 描述 |
---|---|
boolean offerFirst(E e) | 从队头入队 |
boolean offerLast(E e) | 从队尾入队 |
E pollFirst() | 从队头出队 |
E pollLast() | 从队尾出队 |
E peekFirst() | 得到队头元素,不删除 |
E peekLast() | 得到队尾元素,不删除 |
注意: 接下来使用 LinkedList 演示队列的使用方法,只要把握先进先出的原则就行。下面的示例都是一份代码分开拿出来的,上下其实是有逻辑关系的
示例一: 使用 LinkedList 创建一个元素为整型的队列
LinkedList<Integer> linkedList = new LinkedList<>();
示例二: 从队头入队
linkedList.offerFirst(1);
linkedList.offerFirst(2);
linkedList.offerFirst(3);
// 队列为:[3, 2, 1]
示例三: 从队尾入队
linkedList.offerLast(7);
linkedList.offerLast(8);
linkedList.offerLast(9);
// 队列为:[3, 2, 1, 7, 8, 9]
示例四: 从队头出队
System.out.println(linkedList.pollFirst());
// 结果为:3
示例五: 从队尾出队
System.out.println(linkedList.pollLast());
// 结果为:9
示例六: 得到队头元素,不删除
System.out.println(linkedList.peekFirst());
// 结果为:2
示例七: 得到队头元素,不删除
System.out.println(linkedList.peekLast());
// 结果为:8
来源:https://blog.csdn.net/weixin_51367845/article/details/120898298


猜你喜欢
- 前言socket是软件之间通讯最常用的一种方式。c#实现socket通讯有很多中方法,其中效率最高就是异步通讯。异步通讯实际是利用windo
- 前言下面大部分内容来源于网上的相关帖子和官网,自己简单写了个demo体验了下,个人感觉mybatis的缓存并不是很合适查询做缓存时,遇到更新
- 1.vs中生成dll对应的生成dll的cpp如下 #include<opencv2/opencv.hpp>#inclu
- 本文实例讲述了C#实现下载网页HTML源码的方法。分享给大家供大家参考之用。具体方法如下:public static class DownL
- 在我们对程序进行操作过程中,一般都需要有一个操作流程的记录显示。用C#进行编程时可以很容易实现这个功能。本经验提供案例仅供参考下面小编就来介
- 摘要: 前面介绍了MapStrut简单用法,MapStrut的最重要的特点就是处理Java中实体与模型间不匹配属性的转换。实体模型有一个Us
- 前言在写项目的时候经常需要特定的时间做一些特定的操作,尤其是游戏服务器,维护线程之类的,这时候就需要用到定时器。如果此时你刚好用的是spri
- public static void main(String args[]) {Map<String, Object> map
- 1.user实体package com.demo.dto;public class User { private Integer
- 一、前言我们经常会遇到业务想看debug日志的问题,但是debug日志频繁打印会对日志查看有影响,且日志多对系统也会有一定的压力,因此,如果
- 前言平时在搬砖的时候,大家有没有遇到过这样的一个场景,由于各种不可描述因素导致,一个接口返回的数据 里面的 key 是 A , 但是客户端(
- 这篇文章主要介绍了Java如何利用return结束方法调用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要
- 本文实例讲述了Java基于分治法实现的快速排序算法。分享给大家供大家参考,具体如下:package cn.nwsuaf.quick;/**
- smoothstep另一种用法在之前OpenGL Shader-抗锯齿实现文章中所介绍的那样:为了抗锯齿效果可以用smoothstep函数对
- SpringMVC * path路径的坑SpringMVC提供了很方便的 * 供我们开发使用。在配置文件中通过<mvc:mapping
- 前言.NET中的委托是一个类,它定义了方法的类型,是一个方法容器。委托把方法当作参数,可以避免在程序中大量使用条件判断语句的情况。项目名为T
- 这篇文章主要介绍了Java的优先队列PriorityQueue原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学
- 一、首先进行Server的编写:public class SocketServer { private static Socket mSoc
- 该接口实现了序列化,声明为 public interface Key extends SerializableKey 是所有密钥的顶层接口。
- 说点对这几个容易混淆的词的理解:1、c++中的virtual方法的 virtual关键字主要是防止继承中重复继承父类的同一个方法而设置的标识