Java 队列(Queue)简介与经典例子

Java 队列(Queue)简介与经典例子

队列(Queue)是一种常见的数据结构,它按照先进先出(FIFO)的原则管理元素。在Java中,队列是一种广泛使用的数据结构,用于处理多种实际问题。本篇博客将介绍Java中的队列及其基本操作,并通过三个经典例子来说明队列的应用场景。

队列基本概念

队列是一种线性数据结构,其元素按照顺序排列。在队列中,新元素从一端(尾部)入队,而从另一端(头部)出队。这种操作顺序确保了先进入队列的元素先被取出,符合FIFO原则。

在Java中,队列的常见实现类包括LinkedListArrayDeque。Java提供了Queue接口,定义了队列的基本操作,例如enqueue(入队)、dequeue(出队)、peek(查看队头元素)等。

java 复制代码
Queue<String> queue = new LinkedList<>(); // 使用LinkedList实现队列
queue.offer("Element1");
queue.offer("Element2");
String head = queue.poll(); // 出队

经典例子

1. 任务调度

在多线程环境中,任务调度通常使用队列来管理待执行的任务。新任务被加入队列尾部,而工作线程则从队列头部取出任务执行。这种方式能够确保任务按照提交的顺序依次执行,有效避免了线程竞争问题。

java 复制代码
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.LinkedBlockingQueue;

public class TaskScheduler {
    private final BlockingQueue<Runnable> taskQueue;

    public TaskScheduler() {
        this.taskQueue = new LinkedBlockingQueue<>();
    }

    public void submitTask(Runnable task) {
        taskQueue.offer(task);
    }

    public void start() {
        while (true) {
            try {
                Runnable task = taskQueue.take(); // 阻塞直到队列非空
                new Thread(task).start(); // 执行任务
            } catch (InterruptedException e) {
                Thread.currentThread().interrupt();
            }
        }
    }
}

2. 广度优先搜索(BFS)

在图的广度优先搜索中,队列同样扮演重要角色。从起始节点开始,依次将相邻未访问过的节点加入队列,然后从队列中取出节点进行访问。这样可以确保按照层次遍历图的节点,找到最短路径等问题。

java 复制代码
import java.util.LinkedList;
import java.util.Queue;

public class BreadthFirstSearch {
    public void bfs(Graph graph, int start) {
        boolean[] visited = new boolean[graph.getVertexCount()];
        Queue<Integer> queue = new LinkedList<>();

        visited[start] = true;
        queue.offer(start);

        while (!queue.isEmpty()) {
            int currentVertex = queue.poll();
            System.out.print(currentVertex + " ");

            for (int neighbor : graph.getNeighbors(currentVertex)) {
                if (!visited[neighbor]) {
                    visited[neighbor] = true;
                    queue.offer(neighbor);
                }
            }
        }
    }
}

3. 缓存管理

队列也常用于实现缓存,特别是在限制缓存大小时。新数据被加入队尾,而当缓存达到最大容量时,最老的数据从队头被移除,确保缓存大小始终受限。

java 复制代码
import java.util.LinkedList;
import java.util.Queue;

public class CacheManager<T> {
    private final Queue<T> cache;
    private final int maxSize;

    public CacheManager(int maxSize) {
        this.cache = new LinkedList<>();
        this.maxSize = maxSize;
    }

    public void addToCache(T item) {
        if (cache.size() >= maxSize) {
            cache.poll(); // 移除队头元素
        }
        cache.offer(item); // 入队
    }
}

总结

队列是一种基础而强大的数据结构,通过先进先出的特性,它在任务调度、图遍历、缓存管理等场景中都有广泛应用。在Java中,可以使用Queue接口及其实现类来方便地处理队列操作,满足各种需求。希望通过这篇博客,你对Java中的队列有了更深入的理解。

相关推荐
yuhaiqiang10 分钟前
随手 vibecoding 的浏览器插件已经 6000 多次下载,聊聊他的产品设计
前端·后端·面试
geovindu2 小时前
python: Functional Options Pattern
开发语言·后端·python·设计模式·惯用法模式·函数式选项模式
卷无止境3 小时前
C++ 存储类说明符(Storage Class Specifier)大横评
c++·后端
用户019027581613 小时前
量化数据的 batch 接口有多好用?从 1 只到 500 只,批量拉数据的正确姿势
后端
rruining4 小时前
Java设计模式——结构型
后端
卷无止境4 小时前
C++ 编程的一大坑:非常量全局变量是"万恶之源"
c++·后端
Sinclair5 小时前
认识安企CMS-系统和模板文件结构
后端
许彰午5 小时前
MinIO实战——从环境搭建到生产级文件上传的完整链路
后端
柒和远方6 小时前
Phase 7.4 学习博客:为什么多 API 项目需要 Swagger / OpenAPI
前端·后端·架构
柒和远方6 小时前
Phase 7.3 复盘:后台任务不只是“扔进队列”,还要能被看见
前端·后端·架构