C#使用Queue<T>类进行队列设计

目录

一、涉及到的知识点

1.Queue类

2.Queue类的方法和属性

[二、使用C# Queue类的实例](# Queue类的实例)


一、涉及到的知识点

1.Queue类

C#中确实提供了队列类Queue。队列是一种先进先出(FIFO)的数据结构,用于存储和操作对象的有序集合。在C#中,可以使用System.Collections.Generic命名空间中的Queue<T>类来实现队列。队列在按接收顺序存储消息方面非常有用,以便于进行顺序处理。Queue类将队列作为循环数组实现,存储在Queue类中的对象在一端插入,从另一端移除。

cs 复制代码
// 创建一个新的Queue<int>实例
Queue<int> queue = new Queue<int>();

//或

// 创建一个新的Queue<int>实例
Queue<int> myQueue = new();

2.Queue<T>类的方法和属性

Queue<T>类提供了许多方法和属性,用于处理队列中的元素。以下是一些常用的方法:

  • Enqueue(T item):将元素添加到队列的末尾。
  • Dequeue():从队列的开头移除并返回元素。
  • Peek():查看队列开头的元素,但不将其移除。
  • Clear():移除队列中的所有元素。
  • Contains(T item):检查队列是否包含特定的元素。
  • CopyTo(T[] array, int arrayIndex):将队列中的元素复制到一个数组中。
  • Count:获取队列中元素的数量。

二、使用C# Queue类的实例

这个实例演示了如何创建一个Queue<int>实例,向其中添加元素,查看元素,从队列中移除元素,再次查看元素,向队列中添加新元素,查看队列开头的元素,清空队列,以及检查队列是否为空。

cs 复制代码
// 使用C# Queue类的实例

namespace _134_1
{
    class Program
    {
        static void Main(string[] args)
        {
            ArgumentNullException.ThrowIfNull(args);
            // 创建一个新的Queue<int>实例
            Queue<int> myQueue = new();

            // 向队列中添加一些元素
            myQueue.Enqueue(1);
            myQueue.Enqueue(2);
            myQueue.Enqueue(3);

            // 查看队列中的元素
            Console.WriteLine("队列中的元素:");
            foreach (int element in myQueue)
            {
                Console.Write(element + " ");
            }

            // 从队列中移除并返回第一个元素
            int dequeuedElement = myQueue.Dequeue();
            Console.WriteLine("\n已移除的元素:{0}", dequeuedElement);

            // 再次查看队列中的元素
            Console.WriteLine("\n队列中的元素(更新后):");
            foreach (int element in myQueue)
            {
                Console.Write(element + " ");
            }

            // 添加一个新元素到队列
            myQueue.Enqueue(4);

            // 再次查看队列中的元素
            Console.WriteLine("\n队列中的元素(更新后):");
            foreach (int element in myQueue)
            {
                Console.Write(element + " ");
            }
            // 查看队列开头的元素
            Console.WriteLine("\n队列开头的元素:{0}", myQueue.Peek());

            // 清空队列
            myQueue.Clear();

            // 查看队列是否为空
            Console.WriteLine("\n队列是否为空:{0}", myQueue.Count == 0);
        }
    }
}
//运行结果:
/*
队列中的元素:
1 2 3
已移除的元素:1

队列中的元素(更新后):
2 3
队列中的元素(更新后):
2 3 4
队列开头的元素:2

队列是否为空:True

 */
相关推荐
艾莉丝努力练剑2 分钟前
【C语言】学习过程教训与经验杂谈:思想准备、知识回顾(三)
c语言·开发语言·数据结构·学习·算法
witton1 小时前
Go语言网络游戏服务器模块化编程
服务器·开发语言·游戏·golang·origin·模块化·耦合
枯萎穿心攻击2 小时前
ECS由浅入深第三节:进阶?System 的行为与复杂交互模式
开发语言·unity·c#·游戏引擎
Jerry Lau2 小时前
go go go 出发咯 - go web开发入门系列(一) helloworld
开发语言·前端·golang
nananaij2 小时前
【Python基础入门 re模块实现正则表达式操作】
开发语言·python·正则表达式
Micro麦可乐2 小时前
Java常用加密算法详解与实战代码 - 附可直接运行的测试示例
java·开发语言·加密算法·aes加解密·rsa加解密·hash算法
天下一般2 小时前
go入门 - day1 - 环境搭建
开发语言·后端·golang
雷羿 LexChien3 小时前
C++内存泄漏排查
开发语言·c++
小码编匠3 小时前
WPF 自定义TextBox带水印控件,可设置圆角
后端·c#·.net
水果里面有苹果3 小时前
17-C#的socket通信TCP-1
开发语言·tcp/ip·c#