C#栈和队列

一、Stack 栈集合(先入后出)

1. 核心概念

栈是存储数据的容器 ,遵循 先入后出(后进先出 LIFO) 规则。

  • 数据存入:入栈(Push)

  • 数据取出:出栈(Pop)

  • 最先存进去的在栈底,最后存的在栈顶,只能操作栈顶元素

2. 两种定义方式

复制代码
// 1. 泛型栈(推荐、类型安全、无装箱拆箱)
Stack<int> stack = new Stack<int>();

// 2. 非泛型栈(老旧、object存储、类型不安全、有装箱拆箱)
Stack stack1 = new Stack();
stack1.Push("张三"); //栈底
stack1.Push("李四");
stack1.Push("王五"); //栈顶

3. 栈核心五大方法

cs 复制代码
// 1. Push():入栈,数据压入栈顶
stack1.Push("张三");
stack1.Push("李四");
stack1.Push("王五");

// 2. Pop():出栈,删除并返回【栈顶】元素
Console.WriteLine(stack1.Pop()); //输出:王五

// 3. Peek():查看栈顶,只返回不删除
Console.WriteLine(stack1.Peek()); //输出:李四

// 4. Count:获取栈中元素个数
Console.WriteLine(stack1.Count);

// 5. 辅助方法
stack1.Clear();      //清空所有元素
stack1.Contains("张三"); //判断是否包含指定元素

4. 栈的遍历方式

没有索引,不能直接下标遍历,需转数组或 foreach

cs 复制代码
// 方式1:转数组遍历
for (int i = 0; i < stack1.Count; i++)
{
    Console.WriteLine(stack1.ToArray()[i]);
}

// 方式2:foreach 遍历
foreach (var i in stack1)
{
    Console.WriteLine(i + "-----");
}

5. 栈执行流程演示

  • 入栈顺序:张三 → 李四 → 王五

  • 栈内结构:栈底【张三、李四、王五】栈顶

  • Pop() 弹出:先出王五,再出李四,最后出张三


二、Queue 队列集合(先入先出)

1. 核心概念

队列遵循 先入先出(先进先出 FIFO) 规则,类似排队。

  • 数据存入:入队(Enqueue)

  • 数据取出:出队(Dequeue)

  • 先排队的先出去,后排队的后出去

2. 定义与基础用法

cs 复制代码
// 泛型队列(项目推荐、类型安全)
Queue<string> queue = new Queue<string>();

// 入队:从队尾添加元素
queue.Enqueue("hello1");
queue.Enqueue("hello2");
queue.Enqueue("hello3");

3. 队列核心方法

cs 复制代码
// 1. Dequeue():出队,删除并返回【队首】第一个元素
Console.WriteLine(queue.Dequeue()); //hello1

// 2. Peek():只查看队首元素,不删除
Console.WriteLine(queue.Peek()); //hello2

// 3. 其他方法
Console.WriteLine(queue.Count); //元素个数
queue.Clear(); //清空
queue.Contains("hello2"); //判断包含

4. 队列遍历

cs 复制代码
foreach (var item in queue)
{
    Console.WriteLine(item);
}

5. 队列执行流程

  • 入队顺序:hello1 → hello2 → hello3

  • 队首 hello1,队尾 hello3

  • Dequeue 优先取出最先进来的元素


三、Stack 与 Queue 核心区别(必背)

集合 规则 存入方法 取出方法(删+返) 查看方法(只返不删)
Stack 栈 先入后出 Push() Pop() 取栈顶 Peek() 看栈顶
Queue 队列 先入先出 Enqueue() Dequeue() 取队首 Peek() 看队首

四、所有集合访问方式终极总结

  • 数组、List、ArrayList、SortedList:支持索引 下标 访问

  • Dictionary、Hashtable:只能 Key 访问,无索引

  • Stack、Queue无索引,只能专用方法存取,不能下标访问


五、终极背诵口诀

  • 栈 Stack:压栈Push、弹栈Pop,后进先出

  • 队列 Queue:入队Enqueue、出队Dequeue,先进先出

  • Peek:只查看、不删除

  • 泛型集合安全高效,非泛型老旧淘汰

相关推荐
唐青枫2 天前
别再乱用 StartNew:C#.NET TaskFactory 任务调度实战详解
c#·.net
Artech2 天前
[MAF预定义的AIContextProvider-03]ChatHistoryMemoryProvider——赋予Agent从经验中学习的能力
ai·c#·agent·memory·maf
Scout-leaf4 天前
C#摸鱼实录——IoC与DI案例详解
c#
咕白m6254 天前
使用 C# 在 Excel 中应用多种字体样式
后端·c#
Artech4 天前
[MAF预定义的AIContextProvider-02]AgentSkillsProvider——将Agent Skills引入MAF
ai·c#·agent·agent skills·maf
LDR0065 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术5 天前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript
码云数智-园园5 天前
C++20 Modules 模块详解
java·开发语言·spring
swordbob5 天前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
源分享5 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm