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# - 栈 (Stack)

Stack 是一种特殊的集合类型,以 LIFO(后进先出)方式存储元素。C# 包含泛型 Stack<T> 和非泛型 Stack 集合类。建议使用泛型 Stack<T> 集合。

栈适用于以 LIFO 方式存储临时数据,并且你可能希望在检索其值后删除元素。

Stack<T> 特性

  • Stack<T> 是后进先出 (Last In First Out) 集合。
  • 它位于 System.Collection.Generic 命名空间下。
  • Stack<T> 可以包含指定类型的元素。它提供编译时类型检查,并且由于是泛型,因此不会执行装箱-拆箱操作。
  • 可以使用 Push() 方法添加元素。不能使用集合初始化器语法。
  • 可以使用 Pop() 和 Peek() 方法检索元素。它不支持索引器。

创建栈

你可以通过为它能够存储的元素类型指定一个类型参数来创建 Stack<T> 的对象。以下示例使用 Push() 方法在 Stack<T> 中创建并添加元素。栈允许空值(对于引用类型)和重复值。

示例:在栈中创建和添加元素
Stack<int> myStack = new Stack<int>();
myStack.Push(1);
myStack.Push(2);
myStack.Push(3);
myStack.Push(4);

foreach (var item in myStack)
     Console.Write(item + ","); //prints 4,3,2,1,
尝试一下

你也可以从数组创建栈,如下所示。

示例:在栈中创建和添加元素
int[] arr = new int[]{ 1, 2, 3, 4};
Stack<int> myStack = new Stack<int>(arr);

foreach (var item in myStack)
     Console.Write(item + ","); //prints 4,3,2,1,
尝试一下

Stack<T> 属性和方法

属性用法
Count返回栈中元素的总数。
方法用法
Push(T)在栈的顶部插入一个项。
Peek()返回栈顶的项。
Pop()移除并返回栈顶的项。
Contains(T)检查栈中是否存在某个项。
Clear()移除栈中的所有项。

Pop()

Pop() 方法返回栈中的最后一个元素并将其从栈中移除。如果栈为空,它将抛出 InvalidOperationException。因此,在调用 Pop() 方法之前,请务必检查栈中元素的数量。

示例:使用 Pop() 访问栈
Stack<int> myStack = new Stack<int>();
myStack.Push(1);
myStack.Push(2);
myStack.Push(3);
myStack.Push(4);

Console.Write("Number of elements in Stack: {0}", myStack.Count);

while (myStack.Count > 0)
     Console.Write(myStack.Pop() + ",");

Console.Write("Number of elements in Stack: {0}", myStack.Count);
尝试一下
输出
栈中元素数量:4
4,3,2,1,
栈中元素数量:0

Peek()

Peek() 方法返回栈中最后添加的值,但不将其移除。在空栈上调用 Peek() 方法会抛出 InvalidOperationException。因此,在使用 Peek() 方法检索元素之前,请务必检查栈中是否存在元素。

示例:使用 Peek() 检索元素
Stack<int> myStack = new Stack<int>();
myStack.Push(1);
myStack.Push(2);
myStack.Push(3);
myStack.Push(4);

Console.Write("Number of elements in Stack: {0}", myStack.Count);// prints 4

if(myStack.Count > 0){
     Console.WriteLine(myStack.Peek()); // prints 4
     Console.WriteLine(myStack.Peek()); // prints 4
}

Console.Write("Number of elements in Stack: {0}", myStack.Count);// prints 4
尝试一下

Contains()

Contains() 方法检查指定的元素是否存在于栈集合中。如果存在,则返回 true,否则返回 false。

示例:Contains()
Stack<int> myStack = new Stack<int>();
myStack.Push(1);
myStack.Push(2);
myStack.Push(3);
myStack.Push(4);

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

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

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

[email protected]

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

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