news 2026/3/17 19:26:22

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/3/15 14:14:52

还在手动添加元素?C#集合表达式让列表初始化快10倍,你知道吗?

第一章&#xff1a;C#集合表达式概述C# 集合表达式是语言中用于创建和初始化集合对象的简洁语法结构&#xff0c;自 C# 6.0 起逐步引入并不断优化。它们允许开发者以声明式方式定义数组、列表或其他可枚举类型&#xff0c;显著提升代码可读性与编写效率。集合表达式的语法形式 …

作者头像 李华
网站建设 2026/3/16 23:53:04

3.5 基于横盘结构的分析体系——缠论(买卖点)

买卖点 在缠论中,买卖点有基于均线的定义和基于中枢的定义。 一二三类买卖点——基于中枢的定义 一买(一卖反之) 第一类买点均线定义: 短期均线和长期均线最后一次死叉的低点 第一类买点中枢定义: 某级别的下跌趋势中,一个次级别走势类型跌破最后一个缠中说禅中枢形成…

作者头像 李华
网站建设 2026/3/15 4:36:04

C#内联数组到底能有多大?:深入探究Span<T>与Stackalloc的实际边界

第一章&#xff1a;C#内联数组大小的理论边界在C#中&#xff0c;内联数组&#xff08;Inline Arrays&#xff09;是.NET 7引入的一项重要语言特性&#xff0c;允许开发者在结构体中声明固定大小的数组&#xff0c;从而提升性能并减少堆内存分配。这一特性特别适用于高性能场景&…

作者头像 李华
网站建设 2026/3/14 19:56:10

C#跨平台调试日志最佳实践(资深架构师20年经验总结)

第一章&#xff1a;C#跨平台调试日志的核心价值与演进在现代软件开发中&#xff0c;C#已不再局限于Windows平台&#xff0c;随着.NET Core及后续.NET 5的统一&#xff0c;C#实现了真正的跨平台能力。这一转变使得调试日志成为保障应用在Linux、macOS、Docker容器等异构环境中稳…

作者头像 李华
网站建设 2026/3/15 7:39:10

最后更新时间2025-12-19:系统持续迭代功能不断增强

HeyGem 数字人视频生成系统&#xff1a;从技术实现到场景落地的深度解析 在内容创作进入“视频为王”时代的今天&#xff0c;企业与教育机构对高质量数字人视频的需求正以前所未有的速度增长。然而&#xff0c;传统真人出镜拍摄不仅成本高昂、周期漫长&#xff0c;还受限于人员…

作者头像 李华