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

.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属性,以排序后的顺序返回

转:C#常用的集合类型(ArrayList类、Stack类、Queue类、Hashtable类、Sort)的更多相关文章

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

    1.ArrayList类 ArrayList类主要用于对一个数组中的元素进行各种处理.在ArrayList中主要使用Add.Remove.RemoveAt.Insert四个方法对栈进行操作.Add方法 ...

  2. 特殊集合(stack、queue、hashtable的示例及练习)

    特殊集合:stack,queue,hashtable stack:先进后出,一个一个的赋值一个一个的取值,按照顺序. .count           取集合内元素的个数 .push()        ...

  3. Collection两个常见的集合类型: ArrayList可重复集有序 ,HashSet不可重复集

    package seday11; import java.util.ArrayList; import java.util.Collection; import java.util.HashSet; ...

  4. 10-23C#基础--特殊集合(stack、queue、hashtable)

    特殊集合一:stack集合--堆集合 1.定义:堆集合是集合中一种特殊的类,在Stack中也有许多方法和属性,下面一一列举: 命名格式:Stack ss=new Stack(); 2.如何添加数据:p ...

  5. C# 各种常用集合类型的线程安全版本

    在C#里面我们常用各种集合,数组,List,Dictionary,Stack等,然而这些集合都是非线程安全的,当多线程同时读写这些集合的时候,有可能造成里面的数据混乱,为此微软从Net4.0开始专门提 ...

  6. C#语言基础——集合(ArrayList集合)

    集合及特殊集合 集合的基本信息: System.Collections 命名空间包含接口和类,这些接口和类定义各种对象(如列表.队列.位数组.哈希表和字典)的集合.System.Collections ...

  7. JAVA集合类型详解

    一.前言 作为java面试的常客[集合类型]是永恒的话题:在开发中,主要了解具体的使用,没有太多的去关注具体的理论说明,掌握那几种常用的集合类型貌似也就够使用了:导致这一些集合类型的理论有可能经常的忘 ...

  8. IoC容器-Bean管理XML方式(注入集合类型属性)

    Ico操作Bean管理(xml注入集合属性) 1,注入数组类型属性 2,注入List集合类型属性 3,注入Map集合类型属性 (1)创建类,定义数组.list.map.set类型属性,生成对应set方 ...

  9. 如何导出标准模板库(STL)类的实例化和包含STL类对象数据成员的类

    本文翻译自 https://support.microsoft.com/zh-cn/help/168958/how-to-export-an-instantiation-of-a-standard-t ...

随机推荐

  1. tomcat 的自问自答与总结

    目录 1 tomcat 的加载问题,启动后更新是否自动加载 2 tomcat 的context.xml 文件读取顺序与覆盖原则 3 就是 建议的tomcat 配置 4 避免二次部署加载的问题 在查看了 ...

  2. ElasticSearch 基础<转载>

    使用curl命令操作elasticsearch 大岩不灿 发表于 2015年4月25日 浏览 13,463 次 第一:_cat系列_cat系列提供了一系列查询elasticsearch集群状态的接口. ...

  3. 微信小程序——<radio></radio>大小改变

    css样式改变大小: transform:scale(.7);

  4. google 被墙的解决办法

    昨晚无意中发现的东西,分享给各位使用,google搜索技术方面的东西还是很准确的,可惜被墙了,但是上有政策下有对策…… 谷歌地址: http://74.125.224.18/ http://91.21 ...

  5. spark work目录处理 And HDFS空间都去哪了?

    1.说在前面 过完今天就放假回家了(挺高兴),于是提前检查了下个服务集群的状况,一切良好.正在我想着回家的时候突然发现手机上一连串的告警,spark任务执行失败,spark空间不足.我的心突然颤抖了一 ...

  6. html5标签属性translate

    定义 translate 是指标签属性,不是css3样式规则transform的translate,说它的定义吧:规定是否应该翻译元素内容. 了解:translate是HTML5中的新属性 语法 &l ...

  7. c# 连等的写法都做了什么?

    在工作中遇到这样一个问题,批量对变量赋值相同的值时,如下: a = ; b = ; c = ; d = ; 我想这样写: a= b = c = d = ; 分别对应IL: Dup 复制计算堆栈上当前最 ...

  8. Redis-五种数据类型解析

    redis 五种数据结构详解(string,list,set,zset,hash) Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存 ...

  9. Docker:集装箱式“运输”在软件上的实现

    Docker是由PaaS提供商dotCloud在2013年年初创建的一款开源应用引擎,Docker可以自动将任何应用打包成轻量.可移植.自包涵的容器引擎.开发者构建的应用可以一次构建全平台运行,包括本 ...

  10. HDU3416(KB11-O spfa+最大流)

    Marriage Match IV Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...