news 2026/4/2 22:01:24

C#之队列

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C#之队列

C# 队列(Queue)教程:从基础到实战

队列(Queue)是计算机科学中一种重要的数据结构,它遵循"先进先出"(FIFO)原则。在C#中,System.Collections.Queue类提供了队列的实现。本教程将全面介绍C#中队列的使用方法。

1. 队列的基本概念

队列是一种线性数据结构,具有以下特点:

  • 先进先出(FIFO):第一个进入队列的元素将是第一个被移除的元素
  • 两端操作:通常在队尾添加元素,在队首移除元素
  • 应用场景:任务调度、消息传递、广度优先搜索等

2. 创建队列

在C#中,可以使用Queue类来创建队列:

usingSystem;usingSystem.Collections;classProgram{staticvoidMain(){// 创建一个空队列Queuequeue=newQueue();// 使用泛型版本(推荐)Queue<string>stringQueue=newQueue<string>();}}

推荐使用泛型版本Queue<T>,因为它提供了类型安全性和更好的性能。

3. 基本操作

3.1 添加元素(Enqueue)

使用Enqueue方法向队列尾部添加元素:

Queue<string>tasks=newQueue<string>();tasks.Enqueue("任务1");tasks.Enqueue("任务2");tasks.Enqueue("任务3");

3.2 移除元素(Dequeue)

使用Dequeue方法移除并返回队列开头的元素:

stringfirstTask=tasks.Dequeue();// 返回"任务1"Console.WriteLine(firstTask);

3.3 查看队首元素(Peek)

使用Peek方法查看队列开头的元素但不移除它:

stringnextTask=tasks.Peek();// 返回"任务2"但不移除Console.WriteLine(nextTask);

3.4 队列计数

使用Count属性获取队列中的元素数量:

Console.WriteLine($"队列中还有{tasks.Count}个任务");

4. 完整示例

usingSystem;usingSystem.Collections.Generic;classQueueExample{staticvoidMain(){// 创建队列Queue<string>messageQueue=newQueue<string>();// 添加消息messageQueue.Enqueue("第一条消息");messageQueue.Enqueue("第二条消息");messageQueue.Enqueue("第三条消息");Console.WriteLine($"队列初始大小:{messageQueue.Count}");// 处理消息while(messageQueue.Count>0){stringmessage=messageQueue.Dequeue();Console.WriteLine($"处理中:{message}");}Console.WriteLine($"处理后队列大小:{messageQueue.Count}");// 尝试查看空队列的Peektry{stringemptyPeek=messageQueue.Peek();}catch(InvalidOperationExceptionex){Console.WriteLine($"错误:{ex.Message}");}}}

5. 高级用法

5.1 遍历队列

虽然队列设计为FIFO结构,但可以使用foreach循环遍历:

Queue<int>numbers=newQueue<int>();numbers.Enqueue(1);numbers.Enqueue(2);numbers.Enqueue(3);foreach(intnuminnumbers){Console.WriteLine(num);}// 注意:遍历不会移除元素

5.2 转换为数组或列表

// 转换为数组int[]numberArray=numbers.ToArray();// 转换为列表List<int>numberList=newList<int>(numbers);

5.3 线程安全队列

在多线程环境中,可以使用ConcurrentQueue<T>

usingSystem.Collections.Concurrent;ConcurrentQueue<int>concurrentQueue=newConcurrentQueue<int>();concurrentQueue.Enqueue(10);concurrentQueue.Enqueue(20);if(concurrentQueue.TryDequeue(outintresult)){Console.WriteLine(result);}

6. 实际应用场景

6.1 任务调度系统

Queue<Action>taskQueue=newQueue<Action>();// 添加任务taskQueue.Enqueue(()=>Console.WriteLine("任务A执行"));taskQueue.Enqueue(()=>Console.WriteLine("任务B执行"));// 执行任务while(taskQueue.Count>0){vartask=taskQueue.Dequeue();task.Invoke();}

6.2 广度优先搜索(BFS)算法

usingSystem;usingSystem.Collections.Generic;classNode{publicintValue{get;set;}publicList<Node>Children{get;set;}=newList<Node>();}classProgram{staticvoidBFS(Noderoot){if(root==null)return;Queue<Node>queue=newQueue<Node>();queue.Enqueue(root);while(queue.Count>0){Nodecurrent=queue.Dequeue();Console.Write(current.Value+" ");foreach(varchildincurrent.Children){queue.Enqueue(child);}}}staticvoidMain(){// 构建树结构Noderoot=newNode{Value=1};root.Children.Add(newNode{Value=2});root.Children.Add(newNode{Value=3});root.Children[0].Children.Add(newNode{Value=4});root.Children[0].Children.Add(newNode{Value=5});Console.WriteLine("广度优先遍历结果:");Bfs(root);// 输出: 1 2 3 4 5}}

7. 性能考虑

  • Queue<T>EnqueueDequeue操作都是O(1)时间复杂度
  • 当队列容量不足时,会自动扩容,这可能导致性能短暂下降
  • 如果需要固定大小的队列,可以考虑使用CircularBuffer等自定义实现

8. 与栈(Stack)的比较

特性队列(Queue)栈(Stack)
顺序先进先出(FIFO)后进先出(LIFO)
添加方法EnqueuePush
移除方法DequeuePop
查看方法PeekPeek
典型应用任务调度、BFS函数调用、撤销操作

总结

C#中的队列(Queue<T>)是一种简单但强大的数据结构,适用于需要先进先出处理的场景。通过本教程,你应该已经掌握了:

  • 队列的基本概念和操作
  • 如何创建和使用队列
  • 队列的高级用法和实际应用
  • 队列与栈的区别
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/3 3:03:56

HeyGem数字人系统批量生成进度条显示机制揭秘

HeyGem数字人系统批量生成进度条显示机制揭秘 在数字内容生产日益自动化的今天&#xff0c;企业需要快速将一段课程音频适配到多位讲师的视频形象上&#xff0c;教育机构希望为不同地区的学生提供本地化口型同步讲解&#xff0c;短视频团队则要批量生成风格统一的AI主播内容。这…

作者头像 李华
网站建设 2026/3/27 6:17:59

[精品]基于微信小程序的大学生心理疏导防控小程序 UniApp

收藏关注不迷路&#xff01;&#xff01;需要的小伙伴可以发链接或者截图给我 这里写目录标题项目介绍项目实现效果图所需技术栈文件解析微信开发者工具HBuilderXuniappmysql数据库与主流编程语言登录的业务流程的顺序是&#xff1a;毕设制作流程系统性能核心代码系统测试详细视…

作者头像 李华
网站建设 2026/3/31 23:29:31

[精品]基于微信小程序的社区讯息服务系统、社区管理系统 UniApp

收藏关注不迷路&#xff01;&#xff01;需要的小伙伴可以发链接或者截图给我 这里写目录标题项目介绍项目实现效果图所需技术栈文件解析微信开发者工具HBuilderXuniappmysql数据库与主流编程语言登录的业务流程的顺序是&#xff1a;毕设制作流程系统性能核心代码系统测试详细视…

作者头像 李华
网站建设 2026/3/31 7:22:56

我从不会Python到3个月赚了第一个5000元接单——完整学习和变现路线图

2025年10月,我做出了一个决定:学Python。 说这个决定的时候,我需要坦白——我是被逼的。那时候我在考虑要不要辞职,身上没什么积蓄,房租压力大得不行。我看着身边的人靠着一些简单的Python脚本每个月轻松赚几千块,就在想:与其冒着风险裸辞,不如先从副业开始探索。我给…

作者头像 李华
网站建设 2026/4/3 7:08:20

微信联系科哥获取HeyGem系统定制化服务(微信号312088415)

HeyGem 数字人视频生成系统技术解析 在内容创作进入“AI工业化”时代的今天&#xff0c;企业对高质量视频的产出效率提出了前所未有的要求。传统的真人出镜拍摄模式不仅成本高昂、周期漫长&#xff0c;更难以应对多语言、多角色、高频更新的内容需求。正是在这样的背景下&#…

作者头像 李华