C# Queue 队列

Queue本质

Queue是一个C#为我们封装好的类

它的本质也是object[]数组,只是封装了特殊的存储规则

Queue是队列存储容器

队列是一种先进先出的数据结构

先存入的数据先获取,后存入的数据后获取

先进先出

队列无法改变其中的元素 只能进出队列

实在要改 只有清

申明

需要引用命名空间 System.Collections

Queue queue = new Queue();

入队

queue.Enqueue(1);

queue.Enqueue("123");

queue.Enqueue(1.4f);

queue.Enqueue(new Test());

出队

队列中不存在删除的概念

只有取的概念 取出先加入的对象

object v = queue.Dequeue();

Console.WriteLine(v);

v = queue.Dequeue();

Console.WriteLine(v);

查看队头元素 查看是否包含

1.查看队列头部元素但不会移除

v = queue.Peek();

Console.WriteLine(v);

v = queue.Peek();

Console.WriteLine(v);

2.查看元素是否存在于队列中

if( queue.Contains(1.4f) )

{

Console.WriteLine("队列中存在1.4f");

}

遍历

1.长度

Console.WriteLine(queue.Count);

2.用foreach遍历

foreach (object item in queue)

{

Console.WriteLine(item);

}

3.还有一种遍历方式

将队列转换为object数组

object[] array = queue.ToArray();

for (int i = 0; i < array.Length; i++)

{

Console.WriteLine(array[i]);

}

4.循环出列

while(queue.Count>0)

{

object o = queue.Dequeue();

Console.WriteLine(o);

}

Console.WriteLine(queue.Count);


cs 复制代码
class Program
{
  static    Queue queue=new Queue();

    public   static void Main()
    {
        StoreInfo();
        while (queue .Count>0) 
        {
            object o = queue.Dequeue();
            Thread.Sleep(1000);
           Console.WriteLine(o);
        }
        
    }
    protected  static  void StoreInfo()
    {
        for (int i = 0; i < 10; i++)
        {
            queue.Enqueue(i);

        }
    }
相关推荐
c_h_o_i_c_e几秒前
MATLAB 帮助文档设置内置浏览器【Web浏览器/内置浏览器】
开发语言·matlab
橙序员小站3 分钟前
Java 接入Pinecone搭建知识库踩坑实记
java·开发语言·人工智能
CHANG_THE_WORLD5 分钟前
Python元组(Tuple)详解
开发语言·python
豆沙沙包?5 分钟前
2025年--Lc313-662. 二叉树最大宽度--java版
java·开发语言
CoderYanger7 分钟前
C.滑动窗口——2762. 不间断子数组
java·开发语言·数据结构·算法·leetcode·1024程序员节
2401_8370885012 分钟前
Integer.MIN_VALUE 是什么意思?
java·开发语言·算法
好风凭借力,送我上青云14 分钟前
哈夫曼树和哈夫曼编码
c语言·开发语言·数据结构·c++·算法·霍夫曼树
KiefaC17 分钟前
【C++】红黑树的调整
开发语言·c++·算法
第二只羽毛18 分钟前
C++高性能内存池
开发语言·c++·缓存·性能优化
ULTRA??20 分钟前
动态内存管理:C语言malloc极简封装方案(修正版,可申请二维数组)
c语言·开发语言