news 2026/4/18 12:38:17

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/18 5:33:29

3.5 基于横盘结构的分析体系——缠论(级别)

级别 缠论中的级别是指&#xff1a; 所谓走势的级别&#xff0c;从最严格的意义上说&#xff0c;可以从每笔成交构成的最低级别图形不断按照中枢延伸、扩展等的定义精确地确认。 不同级别的图&#xff0c;其实就是对真实走势不同精度的一种模本&#xff0c;例如&#xff0c;一…

作者头像 李华
网站建设 2026/4/18 3:40:02

揭秘C#集合表达式新语法:如何让数组初始化提速80%?

第一章&#xff1a;C#集合表达式与数组性能革命随着 .NET 7 的发布&#xff0c;C# 引入了集合表达式&#xff08;Collection Expressions&#xff09;&#xff0c;这一语言特性极大地简化了数组和集合的初始化方式&#xff0c;同时在底层优化了内存分配模式&#xff0c;带来了显…

作者头像 李华
网站建设 2026/4/18 5:32:33

HeyGem系统能否用于直播场景?离线生成为主

HeyGem系统能否用于直播场景&#xff1f;离线生成为主 在虚拟主播、AI讲师和智能客服日益普及的今天&#xff0c;越来越多企业开始探索“数字人内容自动化”的生产模式。一个常见的疑问随之浮现&#xff1a;像HeyGem这样的AI数字人视频生成系统&#xff0c;能不能直接用在直播中…

作者头像 李华
网站建设 2026/4/18 8:35:33

别在图书馆通宵了!这款AI科研工具,如何让本科论文从“痛苦面具”变“从容通关”?

深夜的图书馆&#xff0c;咖啡杯堆积如山&#xff0c;电脑屏幕前是一张写满迷茫的脸——这可能是无数本科生撰写毕业论文时的真实写照。凌晨两点的大学图书馆里&#xff0c;计算机科学专业的大四学生李浩盯着屏幕上不到三千字的论文草稿&#xff0c;手指悬在键盘上已经半小时没…

作者头像 李华
网站建设 2026/4/18 8:05:14

解锁学术新境界:书匠策AI如何为本科论文写作注入智慧动能

在本科学习的尾声&#xff0c;一篇高质量的毕业论文不仅是对四年学习成果的总结&#xff0c;更是通往未来学术或职业道路的重要敲门砖。然而&#xff0c;面对浩如烟海的文献、错综复杂的逻辑框架以及严苛的格式规范&#xff0c;许多学子常常陷入“选题迷茫症”“逻辑构建困难症…

作者头像 李华