Tutorialsteacher

关注我们

文章
  • C#
  • C# 面向对象编程
  • ASP.NET Core
  • ASP.NET MVC
  • LINQ
  • 控制反转 (IoC)
  • Web API
  • JavaScript
  • TypeScript
  • jQuery
  • Angular 11
  • Node.js
  • D3.js
  • Sass
  • Python
  • Go lang
  • HTTPS (SSL)
  • 正则表达式
  • SQL
  • SQL Server
  • PostgreSQL
  • MongoDB
  • C# - 入门
  • C# - 版本历史
  • C# - 第一个程序
  • C# - 关键词
  • C# - 类和对象
  • C# - 命名空间
  • C# - 变量
  • C# - 隐式类型变量
  • C# - 数据类型
  • 数字
  • 字符串
  • DateTime
  • 结构体
  • 枚举
  • StringBuilder
  • 匿名类型
  • 动态类型
  • 可空类型
  • C# - 值类型和引用类型
  • C# - 接口
  • C# - 运算符
  • C# - if else 语句
  • C# - 三元运算符 ?
  • C# - Switch 语句
  • C# - For 循环
  • C# - While 循环
  • C# - Do-while 循环
  • C# - 分部类
  • C# - Static 关键字
  • C# - 数组
  • 多维数组
  • 交错数组
  • C# - 索引器
  • C# - 泛型
  • 泛型约束
  • C# - 集合
  • ArrayList
  • List
  • SortedList
  • Dictionary
  • Hashtable
  • Stack
  • Queue
  • C# - Tuple
  • C# - ValueTuple
  • C# - 内置异常
  • 异常处理
  • throw 关键字
  • 自定义异常
  • C# - 委托
  • Func 委托
  • Action 委托
  • Predicate 委托
  • 匿名方法
  • C# - 事件
  • C# - 协变
  • C# - 扩展方法
  • C# - 流 I/O
  • C# - File 类
  • C# - FileInfo 类
  • C# - 对象初始化器
  • OOP - 概述
  • 面向对象编程
  • 抽象
  • 封装
  • 关联与组合
  • 继承
  • 多态
  • 方法重写
  • 方法隐藏
  • C# - SOLID 原则
  • 单一职责原则
  • 开闭原则
  • 里氏替换原则
  • 接口隔离原则
  • 依赖倒置原则
  • 设计模式
  • 单例模式
  • 抽象工厂模式
  • 工厂方法模式
Entity Framework Extensions - 提升 EF Core 9
  批量插入
  批量删除
  批量更新
  批量合并

C# - Queue

Queue 是一种特殊类型的集合,它以 FIFO(先进先出)的方式存储元素,这与 Stack 集合完全相反。它按元素添加的顺序包含这些元素。C# 包含泛型 Queue 和非泛型 Queue 集合。建议使用泛型 Queue 集合。

Queue 特性

  • Queue 是 FIFO(先进先出)集合。
  • 它属于 System.Collection.Generic 命名空间。
  • Queue 可以包含指定类型的元素。它提供编译时类型检查,并且由于它是泛型的,因此不执行装箱-拆箱操作。
  • 可以使用 Enqueue() 方法添加元素。不能使用集合初始化器语法。
  • 可以使用 Dequeue() 和 Peek() 方法检索元素。它不支持索引器。

下图展示了 Queue 集合

C# queue

创建队列

您可以创建 Queue 对象,方法是为其可以存储的元素类型指定类型参数。以下示例使用 Enqueue() 方法创建 Queue 并添加元素。Queue 集合允许空值(对于引用类型)和重复值。

示例:在队列中创建并添加元素
Queue<int> callerIds = new Queue<int>();
callerIds.Enqueue(1);
callerIds.Enqueue(2);
callerIds.Enqueue(3);
callerIds.Enqueue(4);

foreach(var id in callerIds)
    Console.Write(id); //prints 1234
尝试一下

Queue 属性和方法

属性用法
Count返回队列中元素的总数。
方法用法
Enqueue(T)将一个项目添加到队列中。
Dequeue从队列开头返回一个项目并将其从队列中移除。
Peek()从队列中返回第一个项目而不将其移除。
Contains(T)检查队列中是否存在某个项目。
Clear()从队列中移除所有项目。

从队列中检索元素

Dequeue() 和 Peek() 方法用于检索队列集合中的第一个元素。Dequeue() 从队列中移除并返回第一个元素,因为队列以 FIFO 顺序存储元素。对空队列调用 Dequeue() 方法将抛出 InvalidOperation 异常。因此,在调用它之前,请务必检查队列的总数是否大于零。

示例:读取队列
Queue<string> strQ = new Queue<string>();
strQ.Enqueue("H");
strQ.Enqueue("e");
strQ.Enqueue("l");
strQ.Enqueue("l");
strQ.Enqueue("o");

Console.WriteLine("Total elements: {0}", strQ.Count); //prints 5

while (strQ.Count > 0)
    Console.WriteLine(strQ.Dequeue()); //prints Hello

Console.WriteLine("Total elements: {0}", strQ.Count); //prints 0
尝试一下

Peek() 方法始终从队列集合中返回第一个项目,而不将其从队列中移除。对空队列调用 Peek() 方法将抛出运行时异常 InvalidOperationException。

示例:Peek()
Queue<string> strQ = new Queue<string>();
strQ.Enqueue("H");
strQ.Enqueue("e");
strQ.Enqueue("l");
strQ.Enqueue("l");
strQ.Enqueue("o");

Console.WriteLine("Total elements: {0}", strQ.Count); //prints 5

if(strQ.Count > 0){
    Console.WriteLine(strQ.Peek()); //prints H
    Console.WriteLine(strQ.Peek()); //prints H
}

Console.WriteLine("Total elements: {0}", strQ.Count); //prints 5
尝试一下

Contains()

Contains() 方法检查队列中是否存在某个项目。如果指定项目存在,则返回 true,否则返回 false。

Contains() 签名:bool Contains(object obj);

示例:Contains()
Queue<int> callerIds = new Queue<int>();
callerIds.Enqueue(1);
callerIds.Enqueue(2);
callerIds.Enqueue(3);
callerIds.Enqueue(4);

callerIds.Contains(2); //true
callerIds.Contains(10); //false
尝试一下
TUTORIALSTEACHER.COM

TutorialsTeacher.com 是您权威的技术教程来源,旨在通过循序渐进的方法,指导您掌握各种网络和其他技术。

我们的内容旨在帮助所有级别的学习者轻松快速地学习技术。通过访问此平台,您承认您已审阅并同意遵守我们的使用条款和隐私政策,这些条款和政策旨在保护您的体验和隐私权。

[email protected]

关于我们使用条款隐私政策
copywrite-symbol

2024 TutorialsTeacher.com. (v 1.2) 版权所有。