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. Doxygen自动文档生成工具在Eclipse中的集成及使用举例

    你有为软件编写说明文档的苦恼吗?当别人甩给你一个庞大的系统,让你根据里面的代码注释理解后写出一份完整的开发文档,你会怎么办?一个个的看代码 然后耗时N天来写吗?这既是一份苦差事也极其耗时,有没有更好的 ...

  2. 使用Akka构建集群(一)

    概述 Akka提供的非常吸引人的特性之一就是轻松构建自定义集群,这也是我要选择Akka的最基本原因之一.如果你不想敲太多代码,也可以通过简单的配置构建一个非常简单的集群.本文为说明Akka集群构建的学 ...

  3. LVS持久化与超时时间问题分析

    前言 在上一篇文章<搭建DNS+LVS(keepAlived)+OpenResty服务器(Docker环境)>中,我搭建了dns+lvs+openresty+web集群:先来回顾一下架构图 ...

  4. asp.net MVC 的处理流程

    之前把笔记都放在空间日志中隐藏起来,今天看到这句话:作为经常从网上索取免费资料的一员,要有回报的思想,也为了让更多的人少走些弯路,想想自己不能这么自私,所以把空间日志搬到博客园来.闲话不说,直接开始. ...

  5. Netty 源码阅读的思考------耗时业务到底该如何处理

    目录大纲: 前言 处理耗时业务的第一种方式-------handler 种加入线程池 处理耗时业务的第二种方式-------Context 中添加线程池 总结:两种方式的对比和思考 前言 熟悉 Net ...

  6. Mybatis一对一,一对多

    一对一 假如有student表(学生表)和student_card表(学生证表). student表中有一个字段self_card用来查student_card,student_card表中有一个st ...

  7. 如何在SpringMVC中使用REST风格的url

    如何在SpringMVC中使用REST风格的url 1.url写法: get:/restUrl/{id} post:/restUrl delete:/restUrl/{id} put:/restUrl ...

  8. EF Codefirst(二)数据注释

    CodeFirst通过分析我们在代码里编写的类,以及类之间的关系生成数据库表,以及表之间的各种关系.数据库的表会涉及到主键,外键,列是否为空,列类型等等. 我们要通过怎样的方式来暴露这些信息呢?   ...

  9. OpenStack的架构详解[精51cto]

    OpenStack既是一个社区,也是一个项目和一个开源软件,它提供了一个部署云的操作平台或工具集.其宗旨在于,帮助组织运行为虚拟计算或存储服务的云,为公有云.私有云,也为大云.小云提供可扩展的.灵活的 ...

  10. linux服务器SSH破解预防方法

    1.linux服务器通过配置 /etc/hosts.deny 禁止对方IP通过SSH登录我的服务器 vim /etc/hosts.deny 2.不用SSH服务的默认端口22,重新设置一个新端口,最好设 ...