队列-来看Java骚操作

队列基本概念

队列(Queue)是一种常见的数据结构,采用先进先出(FIFO,First-In-First
-Out)的策略来管理数据。类似于现实生活中的排队,新元素从队尾进入队列,
而队列中的元素从队头开始依次出队。

在这里插入图片描述

队列的特点及特点分析

- 元素只能从队尾插入,从队头删除。
- 队列中的元素按照插入的顺序依次排列,保持了元素间的相对顺序。
- 只能访问队头和队尾元素,无法访问队列中间的元素。

元素只能从队尾插入,从队头删除

队列中的元素必须按照其插入的顺序排列。新元素只能从队尾插入,而移除元素
只能从队头删除。

在这里插入图片描述

队列中的元素按照插入的顺序依次排列

队列保持了元素间的相对顺序,即插入元素的顺序决定了元素的排列顺序。

只能访问队头和队尾元素,无法访问中间的元素

队列特别强调了对头和队尾的操作,而无法访问队列中间的元素。

在这里插入图片描述

队列的基本操作

- 入队(enqueue):将元素插入到队尾。
- 出队(dequeue):删除队头元素,并返回删除的元素。
- 获取队头元素(front):返回队头元素,但不删除。
- 获取队列长度(size):返回队列中元素的个数。
- 判断队列是否为空(isEmpty):如果队列为空,则返回 true;否则返回 false。

入队(enqueue):将元素插入到队尾。

首先,检查队列是否已满。如果队列已满,无法插入新元素。
如果队列未满,将新元素插入到队列的末尾。
插入操作后,队列的长度会增加。

出队(dequeue):删除队头元素,并返回被删除的元素。

在这里插入图片描述

首先,检查队列是否为空。如果队列为空,无法执行出队操作。
如果队列不为空,删除队列的头部元素,并返回被删除的元素。
删除操作后,队列的长度会减少。

获取队头元素(front):返回队头元素,但不删除。

首先,检查队列是否为空。如果队列为空,无法获取队头元素。
如果队列不为空,返回队列的头部元素,但不对队列做任何修改。

获取队列长度(size):返回队列中元素的个数。

遍历队列,计算队列中元素的个数。

判断队列是否为空(isEmpty):如果队列为空,则返回 true;否则返回false。

检查队列的长度是否为 0。如果队列长度为 0,说明队列为空;否则队列非空。

总结

这些基本操作可以让我们对队列进行常用的操作,插入新元素、删除元素、访问
元素和判断队列的状态。通过正确使用这些操作,我们可以很方便地操作队列并
解决实际问题。

在这里插入图片描述

队列的应用场景

在这里插入图片描述

队列是一种常见的数据结构,在计算机科学的各个领域都有广泛的应用。

- 操作系统中的进程调度
- 网络通信中的消息队列
-  网络通信中的消息队列
- 高性能计算中的任务调度
- 缓存淘汰策略
- 安全性系统中的请求处理

操作系统中的进程调度

在操作系统中,进程按照其到达的顺序排队等待处理。新进程被插入到进程队列
的末尾,而调度器会从队列的头部选择下一个要执行的进程。这遵循队列的先进
先出策略,确保先到达的进程先执行。

网络通信中的消息队列

消息队列被广泛应用于网络通信系统,用于解耦发送者和接收者之间的关系。发
送者将消息放入队列的末尾,接收者从队列的头部获取消息进行处理。这种方式
确保了消息的可靠传递,并减少了发送者和接收者之间的直接耦合。

高性能计算中的任务调度

在高性能计算环境中,任务可能以非常快的速度同时到达。任务调度器使用队列
来管理任务,确保按照先到达的顺序执行任务。新任务被插入到任务队列的末尾,
而调度器会从队列的头部选择下一个要执行的任务。

广度优先搜索算法(BFS)

在图的搜索算法中,广度优先搜索使用队列来维护待访问的节点。从起始节点开
始,将其放入队列中,然后依次访问其相邻节点,并将新访问的节点放入队列尾
部。这样可以确保按照距离从起始节点逐层遍历图,直到达到目标节点。

缓存淘汰策略

在缓存系统中,当缓存空间已满时,需要根据一定的策略来选择要淘汰的缓存项。
常用的策略是最近最少使用(LRU)策略,它维护一个队列,最近被访问过的缓
存项排在队列的末尾。当需要淘汰缓存项时,队列头部的元素即为最少使用的缓
存项。

安全性系统中的请求处理

在安全性系统中,请求可能同时到达,需要按照先到达的顺序进行处理。队列用
于管理请求,确保按照先来先服务的原则进行处理。新请求被插入到队列的末尾,
然后逐个处理,保证公平性和安全性。

这些仅仅是队列应用的一小部分

队列作为一种简单且高效的数据结构,可以在各种情境下应用,例如任务调度、
消息传递、网络通信等。通过合理应用队列,我们可以提高系统的效率和性能,
并简化问题的处理。

注意事项

在使用队列时,有一些注意事项需要考虑,以确保正确、高效地使用这种数据
结构。以下是一些详细的解读:

容量限制

队列的实现通常需要指定最大容量。在使用有界队列时,注意队列是否已满。尝
试向满队列中插入元素将导致操作失败或被阻塞。

线程安全性

如果队列在多个线程中使用,需要注意线程安全性。并发环境下,队列的插入
(enqueue)和删除(dequeue)操作可能会发生冲突。可以使用同步机制(如
锁)或使用线程安全的队列实现来确保操作的原子性和有序性。

内存管理

队列的插入和删除操作可能会涉及内存分配和释放。在频繁操作大量元素的队列
时,需要注意内存管理的效率和分配释放的代价。避免无效的内存重复分配和不
必要的内存泄漏。

元素顺序

队列保持元素插入的相对顺序。插入的新元素位于队列的末尾,删除的元素始终
从队列的头部开始。因此,队列的其他操作不能改变元素的相对顺序。需要注意
保持元素的正确有序性。

队列空/满状态

注意判断队列是否为空或已满。在进行插入或删除操作之前,检查队列状态可以
避免不必要的错误。对于空队列,不要尝试执行删除操作,对于满队列,不要尝
试执行插入操作。

队列的选择

根据具体的应用需求,选择适合的队列实现。不同的队列实现具有不同的性能特
点和适用场景。例如,普通队列、循环队列、阻塞队列、优先级队列等,根据实
际情况选择最佳的队列类型。

异常处理

对于某些队列操作,如删除队头元素或访问空队列的头部,可能会引发异常。在
进行这些操作时,应当捕获和处理相应的异常,以防止程序崩溃或出现错误状态。

避免死锁

在使用同步机制处理并发队列时,需要注意避免死锁。死锁可能发生在多线程环
境中,当各个线程相互等待对方的资源时。合理设计同步机制和避免循环等待可
以减少死锁的风险。

综上

队列的正确使用需要考虑容量限制、线程安全性、内存管理、元素顺序、队列状
态判断、选择合适的队列实现、异常处理以及避免死锁等问题。了解这些注意事
项,可以帮助我们有效地利用队列并避免潜在的问题。

代码实现

public class Queue {private int maxSize;private int[] queueArray;private int front;private int rear;private int size;public Queue(int maxSize) {this.maxSize = maxSize;queueArray = new int[maxSize];front = 0;rear = -1;size = 0;}public boolean isEmpty() {return (size == 0);}public boolean isFull() {return (size == maxSize);}public void enqueue(int item) {if (isFull()) {throw new IllegalStateException("Queue is full. Cannot enqueue.");}rear = (rear + 1) % maxSize;queueArray[rear] = item;size++;}public int dequeue() {if (isEmpty()) {throw new IllegalStateException("Queue is empty. Cannot dequeue.");}int temp = queueArray[front];front = (front + 1) % maxSize;size--;return temp;}public int front() {if (isEmpty()) {throw new IllegalStateException("Queue is empty. No front element.");}return queueArray[front];}public int size() {return size;}
}
这个队列实现使用一个固定大小的数组 queueArray 存储元素,使用 front 和 
rear 分别记录队头和队尾的位置,使用 size 记录队列中的元素个数。enqueue 方法在队尾插入元素,如果队列已满,则抛出异常。
dequeue 方法删除队头元素,并返回被删除的元素,如果队列为空,则抛出异常。
front 方法返回队头元素,但不删除,如果队列为空,则抛出异常。
size 方法返回队列中元素的个数。
isEmpty 方法检查队列是否为空。
isFull 方法检查队列是否已满。
注意,在这个示例中,队列采用循环队列的实现方式,即通过 % 运算符实现队
尾指针 rear 在数组中循环移动。也可以根据具体的需求进行适当的修改和扩展,就不展示了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/29217.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

软件测试行业的困境和迷局

中国的软件测试虽然起点较高,但是软件测试的发展似乎没有想象中那么顺利。 其实每个行业除了有自身领域外,还有属于自己的“生态系统”。属于软件测试的生态系统主要包括后备软件测试人员、软件开发人员和软件管理决策者。后备软件测试人员是软件测试的…

【C语言+sqlite3 API接口】实现水果超市

实验内容: 假如我家开了个水果超市,有以下水果,想实现自动化管理,扫描二维码就能知道当前的水果状态,进货几天了, 好久需要再次进货,那些水果畅销,那些水果不畅销,那些水…

Linux之设备树解耦架构解读-V1.0

术语和缩略语 本文档使用了以下术语和缩略语 Dts:DTS即Device Tree Source,是一个文本形式的文件,用于描述硬件信息。一般都是固定信息,无法变更,无法overlay。 Dtsi:可以理解为dts的公共部分&#xff0…

初识Redis——Redis概述、安装、基本操作

目录 一、NoSQL介绍 1.1什么是NoSQL 1.2为什么会出现NoSQL技术 1.3NoSQL的类别 1.4传统的ACID是什么 1.5 CAP 1.5.1 经典CAP图 1.5.4 什么是BASE 二、Redis概述 2.1 什么是Redis 2.2 Redis能干什么 2.3 Redis的特点 2.4 Redis与memcached对比 2.5 Redis的安装 2.6 Docker安装 三…

机器学习(14)--XGBoost

目录 一、概述 二、CART、GB、GBDT 1、CART 2、BT(Boosting Tree提升树) 3、GBDT(梯度提升树) 4、GBDT在sklearn中的损失函数 三、Sklearn中的GBDT 1、加载模块 2、划分数据集 3、建模 4、与随机森林和线性回归对比 5…

教你快速安装Bootstrap

目录 Bootstrap简介Bootstrap的下载Bootstrap的使用 Bootstrap简介 Bootstrap是美国Twitter公司的设计师Mark Otto和Jacob Thornton合作,基于HTML、CSS、JavaScript开发的简洁、直观、强悍的前端开发框架,它会使Web开发更加快捷Bootstrap框架的优点 开发…

GRE实验

题目参考&#xff1a; 实验步骤&#xff1a; 第一步&#xff1a;地址规划拓扑设计&#xff0c;配置IP地址 R1配置&#xff1a; <Huawei>system-view [Huawei]sy R1 [R1]int g 0/0/1 [R1-GigabitEthernet0/0/1]ip address 192.168.1.1 24 [R1-GigabitEthernet0/0/1]in…

异步fifo(1)

什么时异步fifo FIFO&#xff0c;即First In First Out &#xff0c;是一种先进先出的数据缓存器&#xff0c;异步FIFO 是指读写时钟不一致&#xff0c;读写时钟是互相独立的。数据从一个时钟域写入FIFO缓冲区&#xff0c;并从另一个时钟域的同一FIFO缓冲区中读取数据&#xf…

博弈论--sg函数

sg函数------ 定义终止状态的SG函数值为0。如果游戏已经结束&#xff0c;即达到了终止状态&#xff0c;那么对应的SG函数值就是0。即先手的sg值为0&#xff0c;则先手必败&#xff0c;否则先手必胜。 如何求sg函数值--------对于每个可能的移动&#xff0c;将后续状态的SG函数…

Centos 7 使用国内镜像源更新内核

内核选择参考 此博文 &#xff1a;https://blog.csdn.net/alwaysbefine/article/details/108931626 elrepo官网介绍的内核升级方式为&#xff1a; 一、按文档执行引入 elrepo库&#xff1b; # 1、引入公钥 rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org# 2、安…

JVM学习之内存与垃圾回收篇1

文章目录 1 JVM与Java体系结构1.0 Java发展重大事件1.1 虚拟机和Java虚拟机1.3 JVM整体结构1.4 Java代码执行流程1.5 JVM架构模型1.6 JVM的生命周期1.7 JVM发展历程 2 类加载子系统2.1 ClassLoader2.2 用户自定义类加载器2.2.1 为什么需要自定义类加载器2.2.2 自定义类加载器的…

go初识iris框架(二) - get,post请求和数据格式

继初步了解iris后 文章目录 获取url路径获取数据get请求post请求获取JSON数据格式JSON返回值获取XML数据格式XML返回值 获取url路径 package mainimport "github.com/kataras/iris/v12"func main(){app : iris.New()app.Get("/hello",func(ctx iris.Conte…