当前位置: 首页 > news >正文

C#容器源码分析 --- Queue<T>

Queue<T> 是 System.Collections.Generic 命名空间下的先进先出(FIFO)动态集合,其核心实现基于​​循环数组​​,通过维护头尾指针实现高效入队和出队操作。

.Net4.8 Queue<T>源码地址:queue.cs (microsoft.com)https://referencesource.microsoft.com/#System/compmod/system/collections/generic/queue.cs,aa3beab99b2e0db2

内部结构:

1.主要字段和属性:

_array:这是一个泛型数组,用于实际存储 Queue<T> 中的元素。
_head:代表队列头部元素的索引,也就是最先进入队列的元素的位置。
_tail:表示队列尾部元素的下一个位置的索引,新元素将被添加到这个位置。
_size:表示当前 Queue<T> 中实际存储的元素数量。
_version:用于记录 Queue<T> 的版本号。每当对队列进行添加、删除等修改操作时,这个版本号会增加。它主要用于在迭代队列时检测队列是否被修改,如果被修改则会抛出异常,以保证迭代的安全性。
_MinimumGrow:表示队列的最小扩容的数量。
_GrowFactor:表示每次扩容的因子,就是扩容时放大的倍数。
_DefaultCapacity:这是一个常量,代表 Queue<T> 的默认初始容量,值为 4。当创建一个 Queue<T> 对象在传入一个现有集合时,会使用这个默认值。
_emptyArray:这是一个静态只读的空数组,用于在某些情况下表示空队列。 

2.构造函数:

1.无参构造函数:

2.指定初始容量的构造函数:

3.从现有集合初始化的构造函数:

动态扩容:

当数组元素已满时,队列中的数组会按比例将当前容量扩容,通过设置一个_MinimumGrow值,确保扩容幅度不低于最小增量,防止频繁扩容。

主要方法:

1.Enqueue:

解释: 往队列里增加一个元素队尾指针_trail往后移动一位。

 

2.Dequeue:

解释:将队列头部元素移除,头部指针_head往后移一位。

3.Peek:

解释:将头部数据返回不移出,头部指针_head不往后移动。
 

4.Contains:

EqualityComparer<T>的解释参考Stack<T>的源码分析:
C#容器源码分析 --- Stack<T>-CSDN博客

5.TrimExcess:

相关文章:

  • 2025届蓝桥杯JavaB组个人题解(暂时不全,没题目)
  • 【AI】AI大模型发展史:从理论探索到技术爆发
  • [创业之路-366]:投资尽职调查 - 尽调核心逻辑与核心影响因素:价值、估值、退出、风险、策略
  • webpack vite
  • 基于 Termux 在移动端配置 Ubuntu 系统并搭建工作环境
  • DeepSeek在应急救援领域的应用解决方案
  • docker测试镜像源
  • 如何在运行时获取硬件信息
  • day24 学习笔记
  • Linux:35.其他IPC和IPC原理+信号量入门
  • 自动驾驶的数据集以及yolov8和yolop
  • Oracle 复制表结构(含索引、主键)操作指南
  • 池式结构---内存池
  • 企业年报问答RAG挑战赛冠军方案:从零到SotA,一战封神
  • AI 大语言模型 (LLM) 平台的整体概览与未来发展
  • #关于数据库中的时间存储
  • 006.Gitlab CICD流水线触发
  • Python实现链接KS3,并批量下载KS3文件数据到本地
  • MySQL数据库备份与恢复详解
  • 21 天 Python 计划:MySQL索引机制从基础到应用
  • 视频网站怎样做/公司网站如何制作设计
  • 哪个网站可以做批发/什么是外链
  • 邯郸专业做wap网站/全球疫情最新消息
  • 湛江模板建站多少钱/株洲seo优化报价
  • 临海高端网站设计新感觉建站/怎样才能在百度上面做广告宣传
  • 西宁人大网站建设/最有效的100个营销方法