要选择正确的集合,我们首先要上海徐汇企业网站设计与制作了解一些数据结构的知识。所谓数据结构,就是相互之间存在一种或多种特定关系的数据元素的集合。结合下图,我们看一下对集合的分类。

上海闵行企业网站设计与制作上海徐汇企业网站制作

  集合分类

  在上图中,可以看到,集合总体上分为线性集合和非线性集合。线性集合指元素具有唯一的前驱和后驱的数据结构类型。非线性集合是指具有多个前驱或后驱的数据结构类型,如:树、图。在FCL中,非线性集合实现的比较少,所以我们将会更多的讨论线性集合。

  注意:由于类型安全、转型效率等方面的原因,本建议将只讨论泛型集合。

  线性集合按存储方式,又分为直接存储和顺序存储。所谓直接存储是指:该类型的集合数据元素可以直接通过下标(也即index)来访问,在C#中有三种形式:Array(包括数组和ListT),string,struct。直接存储结构的优点是:向数据结构中添加元素是很高效的,只要直接放在数据末尾的第一个空位上就可以了。它的缺点是:向集合插入元素将会变得低效,它需要给插入的元素腾出位置并顺序移动后面的元素。

  string和structs虽然是直接存储结构,但它们与一般的集合定义有很大的不同,所以也不在本建议讨论之中。在直接存储的数据结构中,需要区分的是数组和ListT的选择。再次强调一下:如果集合的数目固定并且不涉及到转型,使用数组效率高,否则就使用ListT。

  顺序存储结构,也即线性表。线性表的大小可动态的扩大和缩小,它在一片连续的区域中存储数据元素。线性表不能按照索引进行查找,它通过对地址的引用来搜索元素,为了找到某个元素,它必须遍历所有元素,直到找到对应的元素为止。所以线性表的优点是插入和删除数据效率高,而缺点是查找的效率相对来说低一些。

  线性表又可以分为队列、栈以及索引群集,在C#中,分别表现为:QueueT,StackT,索引群集又进一步泛化为字典类型Dictionary TKey, TValue 和双向链表LinkedListT。

  队列QueueT遵循的是先入先出模式,它在集合末尾添加元素,在集合起始删除元素,如图:

队列操作

  根据队列的特点,可以用来处理并发命令等场景:将所有客户端的命令先入队,由专门的工作线程来执行队列的命令。在分布式中的消息队列就是一个典型的队列应用实例。

  栈StackT遵循的是后入先出模式,它在集合末尾添加元素,同时也在集合末尾删除元素,如图2-3:

栈操作

  字典DictionaryTKey, TValue存储的是键值对,值在基于键的散列码的基础上进行存储。字典类对象由包含集合元素的存储桶组成,每一存储桶与基于该元素的键的哈希值关联。如果需要根据键进行值的查找,使用DictionaryTKey, TValue将会使搜索和检索更会快捷。

  双向链表LinkedListT是一个类型为LinkedListNode的元素对象的集合。当我们在集合中觉得插入和删除数据很慢的时上海网站上海企业网站制作建设候,我们可以考虑使用链表。如果我们使用LinkedListT,我们会发现此类型并没有其它集合普遍具有的Add方法,取而代之的是AddAfter、AddBefore、AddFirst、AddLast等方法。双向链表中的每个节点都向前指向Previous节点,向后指向Next节点。

  以上讨论了线性集合,在FCL中,非线性集合实现的不多。非线性集合分为层次集合和组集合。层次集合,如树,在FCL中就没有实现。组集合,又分为集和图。集在FCL中实现为HashSetT,而图在FCL中也没有对应实现。集的概念在本意上是指存放在集合中的元素是无序的且不能重复的。下图演示了集的用途:

集操作

  除了上面我们提到的集合类型,还有其他几个要掌握的集合类型,它们是在实际应用中发展出来的对以上基础类型的扩展:SortedListT,SortedDictionaryTKey, TValue,SortedSetT。它们所扩展的对应类为ListT,DictionaryTKey,TValue,HashSetT,作用是将原本无序排列的元素,变为有序排列。

  除了排序上的需求增加了上面3个集合类,在命名空间System.Collections.Concurrent下,还涉及几个多线程集合类。它们主要是:ConcurrentBagT对应ListT,ConcurrentDictionaryTKey, TValue对应DictionaryTKey, TValue,ConcurrentQueueT对应QueueT,ConcurrentStackT对应StackT。如果我们的集合被用于多线程应用中,可以使用这几个集合类型。关于集合的线程安全性,可以进一步查看MSDN。

  本建议到此为止已经介绍了FCL中的大部分泛型集合类,为了对它们有更好的了解,最后我们给出一个主要集合类的类图。实际工作中,应该根据需要选择合适的集合类。

FCL集合类图

在C#中选择“.NET研究”正确的集合进行编码相关推荐

  1. 改善C#程序的建议3:在C#中选择正确的集合进行编码

    原文:改善C#程序的建议3:在C#中选择正确的集合进行编码 要选择正确的集合,我们首先要了解一些数据结构的知识.所谓数据结构,就是相互之间存在一种或多种特定关系的数据元素的集合.结合下图,我们看一下对 ...

  2. 双色球(投注号码由6个红色球号码和1个蓝色球号码组成。红色号码从1-33中选择;蓝色球号码从1-16中选择。)

    题目: 投注号码由6个红色球号码和1个蓝色球号码组成.红色号码从1-33中选择:蓝色球号码从1-16中选择.输出正确号码,买家选择的双色球号码以及兑奖结果. 中奖说明: 中红色球个数 中蓝色球个数 奖 ...

  3. 从下列选项中选择正确的java表达式,java笔试常见的选择题

    1.已知表达式int m[] = {0,1,2,3,4,5,6}; 下面那个表达式的值与数组的长度相等() A m.length() B. m.length C. m.length()+1 D. m. ...

  4. 《强化学习周刊》第26期:UCL UC Berkeley发表深度强化学习中的泛化研究综述、JHU推出基于强化学习的人工决策模型...

    No.26 智源社区 强化学习组 强 化 学  习 研究 观点 资源 活动 关于周刊 强化学习作为人工智能领域研究热点之一,其研究进展与成果也引发了众多关注.为帮助研究与工程人员了解该领域的相关进展和 ...

  5. 护理在计算机的应用研究,计算机虚拟和模拟技术在护理实践教学中应用的研究...

    计算机应用 邢沈阳计算机虚拟和模拟技术在护理实践教学中应用的研究 1565 计算机虚拟和模拟技术在护理实践教学中应用的研究 邢沈阳,李文涛,高玉霞 (吉林大学护理学院,吉林 长春 130021) [关 ...

  6. 阿尔茨海默病与正常衰老中的脑萎缩研究进展

    得益于其安全性和可靠性,磁共振成像(magnetic resonance imaging, MRI)被广泛应用于临床工作和研究领域,很大程度上能够帮助我们理解阿尔茨海默病(Alzheimer's di ...

  7. 机器分类模型在肺癌病例中的比较研究

    各位朋友,我已开通微信公共号:小程在线 我会把文章及时的更新到公共号上,欢迎大家的关注. 机器分类模型在肺癌病例中的比较研究   摘要:针对机器分类方法在医学数据应用上的差异,使用HIS系统收集的肺癌 ...

  8. google地图 离线版 经纬度_好文推荐:奥维地图在测绘作业中应用的研究

    奥维地图在测绘作业中应用的研究 河北中核岩土工程有限责任公司测绘地理信息事业部 赵健  袁彦玲  张辉 摘要:奥维互动地图采用新技术,集多种知名地图与一体,可以辅助完成测绘项目测区范围确定.测绘项目控 ...

  9. 《多媒体在初中数学中的运用研究》研究论文

    <多媒体在初中数学中的运用研究>研究论文 石头镇初级中学课题组 李佩佩 摘要:随着教学手段的不断改变,多媒体逐渐走进课堂,它在教学中的应用引起了教师的广泛关注.本文主要就多媒体辅助教学在初 ...

最新文章

  1. ArrayList Iterator remove java.lang.UnsupportedOperationException
  2. 网页录音解决方案 FlashWavRecorder For Website API 关键地方已注释
  3. VS Code:史上最全的VS Code快捷键+分门别类(中英文对照版)
  4. 后台(crontab,at,,nohup)
  5. Linux Shell高级技巧(一)
  6. mysql堆溢出_为什么这个MySQL触发器会导致堆栈溢出?
  7. html中prependid的作用,UIForm与prependId =“false”中断
  8. Oracle DataGuard数据备份方案详解
  9. Ubuntu 17 安装Chrome浏览器
  10. 计算机实训大纲,计算机专业实训大纲
  11. 对C语言实验报告的建议,c语言实验报告.docx
  12. ES 处理日志字段超出 1000 引发的报错
  13. 大数据面试3分钟自我介绍_如何在面试时,做好三分钟自我介绍
  14. P5441 【XR-2】伤痕
  15. matlab cos sinx,matlab求y=sinxcos(2x)及其包络线急!!!
  16. 安卓平板隐藏虚拟按键_实现安卓设备虚拟按键隐藏和显示的方法和系统的制作方法...
  17. 网络数据采集分析工具tcpdump定义抓包过滤器
  18. 幸福究竟和哪些因素有关?通过JMP来看全球幸福指数
  19. BZOJ 3876 AHOI2014 支线剧情 费用流
  20. 未来智安XDR与中科方德高可信服务器操作系统完成产品兼容性互认证

热门文章

  1. php图形图像处理技术
  2. UWP_Homework_4 A MediaPlayer
  3. Hadoop(十五)MapReduce程序实例
  4. Windows版 mysql 5.7.16安装
  5. jqm跳转js不加载
  6. java学习之文件基本操作
  7. 程序猿接私活经验总结,来自csdn论坛语录
  8. 【转】Unity+单例模式的依赖注入
  9. servlet之控制分发
  10. web版扫雷小游戏(三)