转:C#常用的集合类型(ArrayList类、Stack类、Queue类、Hashtable类、Sort)
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)的更多相关文章
- C#常用的集合类型(ArrayList类、Stack类、Queue类、Hashtable类、SortedList类)
1.ArrayList类 ArrayList类主要用于对一个数组中的元素进行各种处理.在ArrayList中主要使用Add.Remove.RemoveAt.Insert四个方法对栈进行操作.Add方法 ...
- 特殊集合(stack、queue、hashtable的示例及练习)
特殊集合:stack,queue,hashtable stack:先进后出,一个一个的赋值一个一个的取值,按照顺序. .count 取集合内元素的个数 .push() ...
- Collection两个常见的集合类型: ArrayList可重复集有序 ,HashSet不可重复集
package seday11; import java.util.ArrayList; import java.util.Collection; import java.util.HashSet; ...
- 10-23C#基础--特殊集合(stack、queue、hashtable)
特殊集合一:stack集合--堆集合 1.定义:堆集合是集合中一种特殊的类,在Stack中也有许多方法和属性,下面一一列举: 命名格式:Stack ss=new Stack(); 2.如何添加数据:p ...
- C# 各种常用集合类型的线程安全版本
在C#里面我们常用各种集合,数组,List,Dictionary,Stack等,然而这些集合都是非线程安全的,当多线程同时读写这些集合的时候,有可能造成里面的数据混乱,为此微软从Net4.0开始专门提 ...
- C#语言基础——集合(ArrayList集合)
集合及特殊集合 集合的基本信息: System.Collections 命名空间包含接口和类,这些接口和类定义各种对象(如列表.队列.位数组.哈希表和字典)的集合.System.Collections ...
- JAVA集合类型详解
一.前言 作为java面试的常客[集合类型]是永恒的话题:在开发中,主要了解具体的使用,没有太多的去关注具体的理论说明,掌握那几种常用的集合类型貌似也就够使用了:导致这一些集合类型的理论有可能经常的忘 ...
- IoC容器-Bean管理XML方式(注入集合类型属性)
Ico操作Bean管理(xml注入集合属性) 1,注入数组类型属性 2,注入List集合类型属性 3,注入Map集合类型属性 (1)创建类,定义数组.list.map.set类型属性,生成对应set方 ...
- 如何导出标准模板库(STL)类的实例化和包含STL类对象数据成员的类
本文翻译自 https://support.microsoft.com/zh-cn/help/168958/how-to-export-an-instantiation-of-a-standard-t ...
随机推荐
- linux buff/cache释放
手动释放cache # > /proc/sys/vm/drop_caches
- 2016-06-14 发布 解决Centos7初次开机提示Initial setup of CentOS Linux 7 (core)
安装完成centos7后出现如下提示: Initial setup of CentOS Linux 7 (core) 1) [x] Creat user 2) [!] License informat ...
- Linux系列:Fedora虚拟机设置固定IP上网(配置IP、网关、DNS、防止resolv.conf被重写)
首先声明:该方法在Fedora 17和18版本下有效,其它版本也许可行也许有所差异. 1. 虚拟机相关配置 如果不是虚拟机系统,则这步不需要,若是相关配置详细信息请看“Linux系列:Ubuntu虚 ...
- Spring Security 之 Remember-Me (记住我)
效果:在用户的session(会话)过期或者浏览器关闭后,应用程序仍能记住它.用户可选择是否被记住.(在登录界面选择) “记住”是什么意思? 就是下次你再访问的时候,直接进入系统,而不需要 ...
- mysql进行时
1. 安装 参考 2. 远程连不上数据库 远程连接mysql时,提示“is not allowed to connect to this MySQL server” 解决(授权法): GRANT AL ...
- python 使用 matplotlib.pyplot来画柱状图和饼图
导入包 import matplotlib.pyplot as plt 柱状图 最简柱状图 # 显示高度 def autolabel(rects): for rect in rects: height ...
- 并发编程之 ConcurrentHashMap(JDK 1.8) putVal 源码分析
前言 我们之前分析了Hash的源码,主要是 put 方法.同时,我们知道,HashMap 在并发的时候是不安全的,为什么呢?因为当多个线程对 Map 进行扩容会导致链表成环.不单单是这个问题,当多个线 ...
- JS实现金额转换(将输入的阿拉伯数字)转换成中文
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- [日常] 高性能MySQL-索引
1.mysql的索引工作类似一本书的目录部分,想找某个特定主题,先查找书的目录部分,找到对应的页码2.ORM工具只能生成基本的合法的查询3.索引是在存储引擎层实现的,不是服务器层4.B-tree就是指 ...
- 【Redis】1、Jedis对管道、事务以及Watch的操作来应对高并发
对于一个互联网平台来说,高并发是经常会遇到的场景.最有代表性的比如秒杀和抢购.高并发会出现三个特点: 1.高并发读取 2.高并发写入(一致性) 3.出现超卖问题 前端如何应对? 1.缓存静态数据,例如 ...