常用集合接口系列:http://www.cnblogs.com/fengxiaojiu/p/7997704.html

常用集合类系列:http://www.cnblogs.com/fengxiaojiu/p/7997541.html

大多数集合都在System.Collections,System.Collections.Generic两个命名空间。其中System.Collections.Generic专门用于泛型集合。

针对特定类型的集合类型位于System.Collections.Specialized;命名空间;

线程安全的集合类位于System.Collections.Concurrent;命名空间。

下面是集合和列表实现的接口如下:

一:列表

1 [Serializable]
2 [DebuggerTypeProxy(typeof(Mscorlib_CollectionDebugView<>))]
3 [DebuggerDisplay("Count = {Count}")]
4 public class List<T> : IList<T>, ICollection<T>, IEnumerable<T>, IList, ICollection, IEnumerable  

从这个可以看出,泛型集合List<T>实现了这么多接口,具体接口的信息可以通过工具查看。

using System;
using System.Collections.Generic;namespace ConsoleApplication1
{public class Program{static void Main(string[] args){List<String> list = new List<string>();list.Add("张三");list.Add("李四");list.Add("王五");list.Add("田六");list.Add("赵七");for (int i = 0; i < list.Count; i++){Console.WriteLine("for循环:" + i.ToString() + "=" + list[i]);}list.RemoveAt(0);foreach (String item in list){Console.WriteLine("foreach迭代:" + item);}list.AddRange(new String[] { "Hello1", "Hello2", "Hello3" });list.ForEach(Print);Console.Read();}private static void Print(String item){Console.WriteLine("ForEach:" + item);}}}

二、队列

队列先进先出,一头进一头出,用Queue<T>实现

    [Serializable][DebuggerTypeProxy(typeof(System_QueueDebugView<>))][ComVisible(false)][DebuggerDisplay("Count = {Count}")]public class Queue<T> : IEnumerable<T>, ICollection, IEnumerable

可以看出队列实现了集合的接口,迭代的接口

using System;
using System.Collections.Generic;namespace ConsoleApplication1
{public class Program{static void Main(string[] args){Queue<String> queue = new Queue<string>();//进队queue.Enqueue("张三");queue.Enqueue("李四");queue.Enqueue("王五");queue.Enqueue("田六");queue.Enqueue("赵七");foreach (String item in queue){Console.WriteLine("foreach迭代:" + item);}//出队while (queue.Count > 0){Console.WriteLine("出队:" + queue.Dequeue());}Console.Read();}}
}

三、栈

栈:从同一边先进后出,用Stack<T>实现

 [DebuggerDisplay("Count = {Count}")][DebuggerTypeProxy(typeof(System_StackDebugView<>))][ComVisible(false)]public class Stack<T> : IEnumerable<T>, ICollection, IEnumerable

栈也是实现了集合接口与迭代接口的

using System;
using System.Collections.Generic;namespace ConsoleApplication1
{public class Program{static void Main(string[] args){Stack<String> stack = new Stack<string>();//进栈stack.Push("张三");stack.Push("李四");stack.Push("王五");stack.Push("田六");stack.Push("赵七");foreach (String item in stack){Console.WriteLine("foreach迭代:" + item);}//出栈while (stack.Count > 0){Console.WriteLine("出栈:" + stack.Pop());}Console.Read();}}
}

四、链表

LinkedList是一个双向链表,链表有个有点,就是在链表中间插入、删除元素很快,但是查找中间与末尾的元素很慢,需要一个节点一个节点的去找。

    [Serializable][DebuggerTypeProxy(typeof(System_CollectionDebugView<>))][DebuggerDisplay("Count = {Count}")][ComVisible(false)]public class LinkedList<T> : ICollection<T>, IEnumerable<T>, ICollection, IEnumerable, ISerializable, IDeserializationCallback

由此可见链表也是有集合的特性的,可以迭代,同时还有链表的特性

using System;
using System.Collections.Generic;namespace ConsoleApplication1
{public class Program{static void Main(string[] args){LinkedList<String> lList = new LinkedList<string>();LinkedListNode<String> node = new LinkedListNode<string>("root");lList.AddFirst(node);node = lList.AddAfter(node, "张三");node = lList.AddAfter(node, "李四");node = lList.AddAfter(node, "王五");node = lList.AddAfter(node, "田六");node = lList.AddAfter(node, "赵七");foreach (String item in lList){Console.WriteLine("foreach迭代:" + item);}node = lList.First;Console.WriteLine("第一个元素:" + node.Value);node = lList.Last;Console.WriteLine("最后一个元素:" + node.Value);Console.Read();}}
}

五、有序列表

SortedList采用键-值对存储,键不能重复,并且会根据key进行排序

    [Serializable][DebuggerTypeProxy(typeof(System_DictionaryDebugView<,>))][DebuggerDisplay("Count = {Count}")][ComVisible(false)]public class SortedList<TKey, TValue> : IDictionary<TKey, TValue>, ICollection<KeyValuePair<TKey, TValue>>, IEnumerable<KeyValuePair<TKey, TValue>>, IDictionary, ICollection, IEnumerable

可以看出SortedList不仅具有字典的特性,还有集合,迭代的功能

using System;
using System.Collections.Generic;namespace ConsoleApplication1
{public class Program{static void Main(string[] args){//Key必须唯一,如果不唯一可以考虑Lookup<TKey,TElement>SortedList<int, String> sList = new SortedList<int, string>();sList.Add(100, "张三");sList.Add(21, "李四");sList.Add(13, "王五");sList.Add(44, "田六");sList.Add(35, "赵七");foreach (KeyValuePair<int, String> item in sList){Console.WriteLine("key=" + item.Key.ToString() + ";value=" + item.Value);}Console.Read();}}
}

六、字典

字典是很复杂的数据结构,允许通过key来查找值,字典可以自由添加、删除元素,没有集合由于移动元素导致的开销。

[Serializable][DebuggerTypeProxy(typeof(Mscorlib_DictionaryDebugView<,>))][DebuggerDisplay("Count = {Count}")][ComVisible(false)]public class Dictionary<TKey, TValue> : IDictionary<TKey, TValue>, ICollection<KeyValuePair<TKey, TValue>>, IEnumerable<KeyValuePair<TKey, TValue>>, IDictionary, ICollection, IEnumerable, ISerializable, IDeserializationCallback

可以看出字典也具有集合的特性,可以迭代

using System;
using System.Collections.Generic;namespace ConsoleApplication1
{public class Program{static void Main(string[] args){//Key必须唯一Dictionary<int, String> dict = new Dictionary<int, string>();dict.Add(11, "张三");dict.Add(1, "李四");dict.Add(2, "王五");dict.Add(16, "田六");dict.Add(12, "赵七");foreach (KeyValuePair<int, String> item in dict){Console.WriteLine("key=" + item.Key.ToString() + ";value=" + item.Value);}Console.Read();}}
}

说到字典,顺便谈一下有序字典,与有序列表对应;SortedDictionary,SortedList,SortedSet

会根据Key进行排序

using System;
using System.Collections.Generic;namespace ConsoleApplication1
{public class Program{static void Main(string[] args){//Key必须唯一SortedDictionary<int, String> dict = new SortedDictionary<int, string>();dict.Add(11, "张三");dict.Add(1, "李四");dict.Add(2, "王五");dict.Add(16, "田六");dict.Add(12, "赵七");foreach (KeyValuePair<int, String> item in dict){Console.WriteLine("key=" + item.Key.ToString() + ";value=" + item.Value);}Console.Read();}}
}

七、集

集(Set):包含不重复元素,常用HashSet,SortedSet

 [Serializable][DebuggerDisplay("Count = {Count}")][DebuggerTypeProxy(typeof(HashSetDebugView<>))]public class HashSet<T> : ISerializable, IDeserializationCallback, ISet<T>, ICollection<T>, IEnumerable<T>, IEnumerable
 [Serializable][DebuggerTypeProxy(typeof(SortedSetDebugView<>))][DebuggerDisplay("Count = {Count}")]public class SortedSet<T> : ISet<T>, ICollection<T>, IEnumerable<T>, ICollection, IEnumerable, ISerializable, IDeserializationCallback

using System;
using System.Collections.Generic;namespace ConsoleApplication1
{public class Program{static void Main(string[] args){HashSet<String> hSet = new HashSet<string>();hSet.Add("张三");hSet.Add("李四");hSet.Add("王五");hSet.Add("田六");hSet.Add("赵七");foreach (String item in hSet){Console.WriteLine("foreach迭代:" + item);}Console.Read();}}
}

using System;
using System.Collections.Generic;namespace ConsoleApplication1
{public class Program{static void Main(string[] args){SortedSet<String> hSet = new SortedSet<string>();hSet.Add("张三");hSet.Add("李四");hSet.Add("王五");hSet.Add("田六");hSet.Add("赵七");foreach (String item in hSet){Console.WriteLine("foreach迭代:" + item);}Console.Read();}}
}

性能比较:

ps:原文链接:http://blog.csdn.net/ceclar123/article/details/8655853

c#中常用集合类和集合接口之接口系列【转】相关推荐

  1. c#中常用集合类和集合接口之集合类系列

    常用集合类: 数组(Array)的不足(即:集合与数组的区别) 1. 数组是固定大小的,不能伸缩.虽然System.Array.Resize这个泛型方法可以重置数组大小,但是该方法是重新创建新设置大小 ...

  2. Java中常用的类,包,接口

    Java中常用的类,包,接口 包名 说明 java.lang 该包提供了Java编程的基础类,例如 Object.Math.String.StringBuffer.System.Thread等,不使用 ...

  3. Dataset:数据集集合(综合性)——机器学习、深度学习算法中常用数据集大集合(建议收藏,持续更新)

    Dataset:数据集集合(综合性)--机器学习.深度学习算法中常用数据集大集合(建议收藏,持续更新) 目录 常规数据集 各大方向分类数据集汇总 具体数据集分类 相关文章 DL:关于深度学习常用数据集 ...

  4. 工作中常用的Stream集合处理

    前言:Java8的新特性主要是Lambda表达式和流,当流和Lambda表达式结合起来一起使用时,因为流申明式处理数据集合的特点,它允许把函数作为一个方法的参数,让我们的代码更优雅简洁. Java8最 ...

  5. Java中常用集合类对比_集合比较

    集合实现类 集合接口 有序性 唯一性 线程安全 空值 性能 排序 数据结构 索引 应用场景 备注 ArrayList List 有序 可重复 不安全 允许空值 查找效率高,添加/删除效率低 使用 Co ...

  6. java容量_java中常用集合类的容量

    这里要讨论这些常用的默认初始容量和扩容的原因是: 当底层实现涉及到扩容时,容器或重新分配一段更大的连续内存(如果是离散分配则不需要重新分配,离散分配都是插入新元素时动态分配内存),要将容器原来的数据全 ...

  7. java中的集合_Java 集合介绍,常用集合类

    JAVA 集合 在处理数据的过程中经常会需要一个容器来存储某一类型的数据,Java 中的数组就是这样一种容器.但 Java 中的数组有其局限性,定义后的数组长度不可变,超出数组长度后就不能再存放数据了 ...

  8. hashmap应用场景_工作中常用到的Java集合有哪些?应用场景是什么?

    秋招Java面试大纲:Java+并发+spring+数据库+Redis+JVM+Netty等 疫情期间"闭关修炼",吃透这本Java核心知识,跳槽面试不心慌 Spring全家桶笔记 ...

  9. Java核心(集合类1-概述、Collection 接口 、List 集合)

    一.集合类概述 java.util 包中提供了一些集合类,这些集合类又被称为容器.集合类与数组的不同之处是,数组的长度是固定的,集合的长度是可变的:数组用来存放基本类型的数据,集合用来存放对象的引用, ...

最新文章

  1. 5G将改变技术格局的8个原因(上)
  2. 查看文件的MD5/SHA1效验值
  3. 常见网络加速技术浅谈(二)
  4. Ubuntu NEF to JPEG(Linux NEF 原生格式转jpeg)
  5. 错误日志这样排查,干活更得劲了!!
  6. python用辗转相除法求最大公约数
  7. 【Spring Bean的生命周期】
  8. 数塔 简单的 动态规划
  9. 计算机WORD列宽行高怎么设置,高会《职称计算机》Word 2007:设置行高和列宽
  10. php商城项目开发视频_ThinkPHP开发大型商城项目实战视频_ThinkPHP商城开发案例
  11. 融云助力中国企业打造海外云平台
  12. 海康摄像头视频视频转码H264处理
  13. Android和风SDK,Android 和风天气SDK获取天气
  14. js爬山之作用域和自由变量~~狂徒李四
  15. C++ 虚函数表 vfptr详解
  16. VLC控件——属性和方法 .
  17. 《百年中国文学史》狂人日记
  18. 自然科学计算机技术ppt,[自然科学]图像处理.ppt
  19. 【Alpha】阶段第二次Scrum Meeting
  20. MeeGo维基介绍如何在WeTab上安装 手机版meego系统

热门文章

  1. 软考解析:2017年上半年下午试卷
  2. 2017.4.17------软件测试的艺术+整理以前的摘记
  3. nios ii小实验——第一个demo指导书
  4. mongodb3.0 性能測试报告 一
  5. C++刷称号——2707: 素数与要素
  6. linux下swftools 的配置
  7. Office - 安装程序找不到office.zh-cn\*.文件
  8. [Leedcode][第215题][JAVA][数组中的第K个最大元素][快排][优先队列]
  9. word导入mysql表格_数据插入Word 表格步骤
  10. java+向前进一_Java 线程基础