C#常用的集合类型(ArrayList类、Stack类、Queue类、Hashtable类、SortedList类)

简介: 1.ArrayList类 ArrayList类主要用于对一个数组中的元素进行各种处理。在ArrayList中主要使用Add、Remove、RemoveAt、Insert四个方法对栈进行操作。Add方法用于将对象添加到 ArrayList 的结尾处;Remove方法用于从 ArrayList 中移除特定对象的第一个匹配项;RemoveAt方法用于移除 ArrayList 的指定索引处的元素;Insert方法用于将元素插入 ArrayList 的指定索引处。
1.ArrayList类
ArrayList类主要用于对一个数组中的元素进行各种处理。在ArrayList中主要使用Add、Remove、RemoveAt、Insert四个方法对栈进行操作。Add方法用于将对象添加到 ArrayList 的结尾处;Remove方法用于从 ArrayList 中移除特定对象的第一个匹配项;RemoveAt方法用于移除 ArrayList 的指定索引处的元素;Insert方法用于将元素插入 ArrayList 的指定索引处。
   示例    ArrayList的使用
示例将介绍如何创建一个ArrayList,如何添加项、移除项以用如何遍历ArrayList。程序代码如下:
 
using System.Collections;//引入命名空间 
namespace _4 
{ 
    class ArrayListTest 
    { 
        static void Main(string[] args) 
        { 
            ArrayList arrlist = new ArrayList();//实例化一个ArrayList对象 
            //使用Add方法向ArrayList中添加元素,将元素添加到ArrayList对象的末尾 
            arrlist.Add("苹果"); 
            arrlist.Add("香蕉"); 
            arrlist.Add("葡萄"); 
            foreach (int n in new int[3] { 0, 1, 2 }) 
            { 
                arrlist.Add(n); 
            } 
            //移除值为的第一个元素 
            arrlist.Remove(0); 
            //移除当前索引为的元素,即第个元素 
            arrlist.RemoveAt(3); 
            //在指定索引处添加一个元素 
            arrlist.Insert(1, "apple"); 
            //遍历ArrayList,并输出所有元素 
            for (int i = 0; i < arrlist.Count; i++) 
            { 
                Console.WriteLine(arrlist[i].ToString()); 
            } 
        } 
    } 
}
 

2.Stack类
Stack(堆栈)类主要实现了一个LIFO(Last In First Out,后进先出)的机制。元素从栈的顶部插入(入栈操作),也从堆的顶部移除(出栈操作)。在Stack中主要使用Push,Pop,Peek三个方法对栈进行操作。Push方法用于将对象插入 Stack 的顶部;Pop方法用于移除并返回位于 Stack 顶部的对象;Peek方法用于返回位于 Stack 顶部的对象但不将其移除。
   示例     Stack的使用
示例将介绍如何创建一个Stack,如何添加项、移除项以用如何遍历Stack。程序代码如下:
 
using System.Collections;//引入命名空间 
namespace _5 
{ 
    class StackTest 
    { 
        static void Main(string[] args) 
        { 
            //实例化Stack类的对象 
            Stack stack = new Stack(); 
            //入栈,使用Pust方法向Stack对向中添加元素 
            for (int i = 1; i < 6;i++) 
            { 
                stack.Push(i); 
                Console.WriteLine("{0}入栈",i); 
            } 
            //返回栈顶元素 
            Console.WriteLine ("当前栈顶元素为:{0}",stack.Peek().ToString ()); 
            //出栈 
            Console.WriteLine("移除栈顶元素:{0}", stack.Pop().ToString()); 
            //返回栈顶元素 
            Console.WriteLine("当前栈顶元素为:{0}", stack.Peek().ToString()); 
            //遍历栈 
            Console.WriteLine("遍历栈"); 
            foreach (int i in stack) 
            { 
                Console.WriteLine(i); 
            } 
            //清空栈 
            while(stack .Count!=0) 
            { 
                int s = (int)stack.Pop(); 
                Console.WriteLine("{0}出栈",s); 
            } 
        } 
    } 
} 

3.Queue类

Queue(队列)类主要实现了一个FIFO(First In First Out,先进先出)的机制。元素在队列的尾部插入(入队操作),并从队列的头部移出(出队操作)。在Queue中主要使用Enqueue、Dequeue、Peek三个方法对队进行操作。Enqueue方法用于将对象添加到 Queue 的结尾处;Dequeue方法移除并返回位于 Queue 开始处的对象;Peek方法用于返回位于 Queue 开始处的对象但不将其移除。
   示例     Queue的使用
示例将介绍如何创建一个Queue,如何添加项、移除项以用如何遍历Queue。程序代码如下:
 
using System.Collections;//引入命名空间 
namespace _6 
{ 
    class QueueTest 
    { 
        static void Main(string[] args) 
        { 
            //实例化Queue类的对象 
            Queue queue = new Queue(); 
            //入栈,使用Pust方法向Stack对向中添加元素 
            for (int i = 1; i < 6; i++) 
            { 
                queue .Enqueue(i); 
                Console.WriteLine("{0}入队", i); 
            } 
            //返回队开始处的元素 
            Console.WriteLine("当前队开始处元素为:{0}", queue.Peek().ToString()); 
            //遍历队 
            Console.WriteLine("遍历队"); 
            foreach (int i in queue) 
            { 
                Console.WriteLine(i); 
            } 
            //清空栈 
            while (queue.Count != 0) 
            { 
                int q = (int)queue.Dequeue (); 
                Console.WriteLine("{0}出队", q); 
            } 
        } 
    } 
}
4.Hashtable类
Hashtable(哈希表)是一种键/值对集合,这些键/值对根据键的哈希代码进行组织。在一个Hashtable中插入一对Key/Value时,它自动将Key值映射到Value,并允许获取与一个指定的Key相关联的value。在Hashtable中主要使用Add、Remove两个方法对哈希表进行操作。Add方法用于将带有指定键和值的元素添加到 Hashtable 中;Remove方法用于从 Hashtable 中移除带有指定键的元素。
   示例    Hashtable的使用
示例将介绍如何创建一个Hashtable,如何添加项、移除项以用如何遍历Hashtable。程序代码如下:
 

using System.Collections;//引入命名空间 
  
namespace _7 
{ 
    class HashtableTest 
    { 
        static void Main(string[] args) 
        { 
            //实例化Hashtable类的对象 
            Hashtable student=new Hashtable (); 
            //向Hashtable中添加元素 
            student.Add("S1001","Tom"); 
            student.Add("S1002", "Jim"); 
            student.Add("S1003", "Lily"); 
            student.Add("S1004", "Lucy"); 
            //遍历Hashtable 
            foreach (DictionaryEntry element in student) 
            { 
                string id = element.Key.ToString (); 
                string name = element.Value.ToString (); 
                Console.WriteLine("学生的ID:{0}   学生姓名:{1}",id,name); 
            } 
            //移除Hashtable中的元素 
            student.Remove("S1003"); 
        } 
    } 
}
   说明:Hashtable不能包含重复的key。如果调用Add 方法来添加一个keys数组中已有的key,就会抛出异常。为了避免这种情况,可以使用ContainsKey方法来测试哈希表中是否包含一个特定的Key。
 

5.SortedList类
SortedList类也是键/值对的集合,但与哈希表不同的是这些键/值对是按键排序,并可以按照键和索引访问。在SortedList中主要使用Add、Remove、RemoveAt三个方法对SortedList进行操作。Add方法用于将带有指定键和值的元素添加到 SortedList中;Remove方法用于从 SortedList 中移除带有指定键的元素;RemoveAt方法用于移除 SortedList 的指定索引处的元素。
   示例    SortedList的使用
示例将介绍如何创建一个SortedList,如何添加项、移除项以用如何遍历SortedList。程序代码如下:
 
using System.Collections;//引入命名空间 
  
namespace _8 
{ 
    class SortedListTest 
    { 
        static void Main(string[] args) 
        { 
            //实例化SortedListTest类的对象 
            SortedList student = new SortedList(); 
            //向SortedList中添加元素 
            student.Add("S1001", "Tom"); 
            student.Add("S1003", "Jim"); 
            student.Add("S1002", "Lily"); 
            student.Add("S1004", "Lucy"); 
            //遍历SortedList 
            foreach (DictionaryEntry element in student) 
            { 
                string id = element.Key.ToString(); 
                string name = element.Value.ToString(); 
                Console.WriteLine("学生的ID:{0}   学生姓名:{1}", id, name); 
            } 
            //移除SortedList中key为“S1003”的元素 
            student.Remove("S1003"); 
            //移除SortedList中索引为“”的元素,即第一个元素 
            student.RemoveAt(0); 
        } 
    } 
}

   说明:同样SortedList也不能包含重复的key。而且使用foreach语句遍历SortedList对象时,会返回DictionaryEntry对象。该对象将根据Key属性,以排序后的顺序返回

  

目录
相关文章
|
2天前
|
Java 物联网 C#
C#/.NET/.NET Core学习路线集合,学习不迷路!
C#/.NET/.NET Core学习路线集合,学习不迷路!
|
2月前
|
存储 C# 索引
C# 一分钟浅谈:数组与集合类的基本操作
【9月更文挑战第1天】本文详细介绍了C#中数组和集合类的基本操作,包括创建、访问、遍历及常见问题的解决方法。数组适用于固定长度的数据存储,而集合类如`List<T>`则提供了动态扩展的能力。文章通过示例代码展示了如何处理索引越界、数组长度不可变及集合容量不足等问题,并提供了解决方案。掌握这些基础知识可使程序更加高效和清晰。
77 2
|
17天前
|
编译器 C#
c# - 运算符<<不能应用于long和long类型的操作数
在C#中,左移运算符的第二个操作数必须是 `int`类型,因此需要将 `long`类型的位移计数显式转换为 `int`类型。这种转换需要注意数据丢失和负值处理的问题。通过本文的详细说明和示例代码,相信可以帮助你在实际开发中正确使用左移运算符。
27 3
|
16天前
|
编译器 C#
c# - 运算符<<不能应用于long和long类型的操作数
在C#中,左移运算符的第二个操作数必须是 `int`类型,因此需要将 `long`类型的位移计数显式转换为 `int`类型。这种转换需要注意数据丢失和负值处理的问题。通过本文的详细说明和示例代码,相信可以帮助你在实际开发中正确使用左移运算符。
33 1
|
1月前
|
开发框架 NoSQL MongoDB
C#/.NET/.NET Core开发实战教程集合
C#/.NET/.NET Core开发实战教程集合
|
15天前
|
编译器 C#
c# - 运算符<<不能应用于long和long类型的操作数
在C#中,左移运算符的第二个操作数必须是 `int`类型,因此需要将 `long`类型的位移计数显式转换为 `int`类型。这种转换需要注意数据丢失和负值处理的问题。通过本文的详细说明和示例代码,相信可以帮助你在实际开发中正确使用左移运算符。
9 0
|
1月前
|
C#
C# 可空类型(Nullable)
C# 单问号 ? 与 双问号 ??
46 12
|
2月前
|
SQL 开发框架 安全
并发集合与任务并行库:C#中的高效编程实践
在现代软件开发中,多核处理器普及使多线程编程成为提升性能的关键。然而,传统同步模型在高并发下易引发死锁等问题。为此,.NET Framework引入了任务并行库(TPL)和并发集合,简化并发编程并增强代码可维护性。并发集合允许多线程安全访问,如`ConcurrentQueue&lt;T&gt;`和`ConcurrentDictionary&lt;TKey, TValue&gt;`,有效避免数据不一致。TPL则通过`Task`类实现异步操作,提高开发效率。正确使用这些工具可显著提升程序性能,但也需注意任务取消和异常处理等常见问题。
46 1
|
3月前
|
存储 C#
揭秘C#.Net编程秘宝:结构体类型Struct,让你的数据结构秒变高效战斗机,编程界的新星就是你!
【8月更文挑战第4天】在C#编程中,结构体(`struct`)是一种整合多种数据类型的复合数据类型。与类不同,结构体是值类型,意味着数据被直接复制而非引用。这使其适合表示小型、固定的数据结构如点坐标。结构体默认私有成员且不可变,除非明确指定。通过`struct`关键字定义,可以包含字段、构造函数及方法。例如,定义一个表示二维点的结构体,并实现计算距离原点的方法。使用时如同普通类型,可通过实例化并调用其成员。设计时推荐保持结构体不可变以避免副作用,并注意装箱拆箱可能导致的性能影响。掌握结构体有助于构建高效的应用程序。
103 7
|
3月前
|
程序员 C#
C# 语言类型全解
C# 语言类型全解
24 0