转载:http://www.cnblogs.com/wisdomforce/archive/2010/05/23/1742098.html
C#集合之STACK
1、Stack定义
System.Collections.Stack类表示对象的简单的后进先出非泛型集合。
2.优点
1、后进先出的集合。
2、Stack 能接受空引用作为有效值并且允许重复的元素
3. Stack的构造器
构造器函数 |
注释 |
初始化 Stack 类的新实例,该实例为空并且具有默认初始容量。 |
|
初始化 Stack 类的新实例,该实例包含从指定集合复制的元素并且具有与所复制的元素数相同的初始容量。 |
|
初始化 Stack 类的新实例,该实例为空并且具有指定的初始容量或默认初始容量(这两个容量中的较大者)。 |
4、Stack的属性
属性名 |
注释 |
获取 Stack 中包含的元素数。 |
5. Stack的方法
方法名 |
注释 |
Void Clear() |
从 Stack 中移除所有对象。 |
Bool Contains(object obj) |
确定某元素是否在 Stack 中。 |
Object Clone() |
创建 Stack 的浅表副本。 |
Void CopyTo(Array array,int index) |
从指定数组索引开始将 Stack 复制到现有一维 Array中。 |
Object Pop() |
移除并返回位于 Stack 顶部的对象。 |
Void Push(object obj) |
将对象插入 Stack 的顶部。 |
Object Peek() |
返回位于 Stack 顶部的对象但不将其移除。 |
Object[]ToArray() |
将 Stack 复制到新数组中。 |
6、Stack的使用示例
1 class Program 2 { 3 public static void Main() 4 { 5 6 //创建一个堆栈 7 Stack myStack = new Stack(); 8 myStack.Push("The");//入栈 9 myStack.Push("quick"); 10 myStack.Push("brown"); 11 myStack.Push("fox"); 12 13 14 // 打印集合中的值 15 Console.Write("Stack values:"); 16 PrintValues(myStack, ' '); 17 18 // 打印堆栈顶部的第一个元素,并将其移除 19 Console.WriteLine("(Pop) {0}", myStack.Pop()); 20 21 //打印集合中的值 22 Console.Write("Stack values:"); 23 PrintValues(myStack, ' '); 24 25 // 打印堆栈顶部的第一个元素,并将其移除 26 Console.WriteLine("(Pop) {0}", myStack.Pop()); 27 28 //打印集合中的值 29 Console.Write("Stack values:"); 30 PrintValues(myStack, ' '); 31 32 // 打印堆栈顶部的第一个元素 33 Console.WriteLine("(Peek) {0}", myStack.Peek()); 34 35 // 打印集合中的值 36 Console.Write("Stack values:"); 37 PrintValues(myStack, ' '); 38 Console.Read(); 39 } 40 41 42 public static void PrintValues(IEnumerable myCollection, char mySeparator) 43 { 44 foreach (Object obj in myCollection) 45 Console.Write("{0}{1}", mySeparator, obj); 46 Console.WriteLine(); 47 } 48 49 }
7.备注
1、Stack 的容量是 Stack 可以保存的元素数。Stack 的默认初始容量为 10。向 Stack 添加元素时,将通过重新分配来根据需要自动增大容量。
2、容量是 Stack 可存储的元素数。Count 是 Stack 中实际存储的元素数,容量始终大于或等于 Count。如果在添加元素时 Count 超过容量,则通过在复制旧元素和添加新元素之前重新分配内部数组来自动增大容量