ImageVerifierCode 换一换
格式:DOCX , 页数:4 ,大小:107.69KB ,
资源ID:2398621      下载积分:15 文钱
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,省得不是一点点
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wenke99.com/d-2398621.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(C#选择正确的集合进行编码.docx)为本站会员(hw****26)主动上传,文客久久仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知文客久久(发送邮件至hr@wenke99.com或直接QQ联系客服),我们立即给予删除!

C#选择正确的集合进行编码.docx

1、要选择正确的集合,我们首先要了解一些数据结构的知识。所谓数据结构,就是相互之间存在一种或多种特定关系的数据元素的集合。结合下图,我们看一下对集合的分类。 集合分类 在上图中,可以看到,集合总体上分为线性集合和非线性集合。线性集合指元素具有唯一的前驱和后驱的数据结构类型。非线性集合是指具有多个前驱或后驱的数据结构类型,如:树、图。在 FCL 中,非线性集合实现的比较少,所以我们将会更多的讨论线性集合。 注意:由于类型安全、转型效率等方面的原因,本建议将只讨论泛型集合。 线性集合按存储方式,又分为直接存储和顺序存储。所谓直接存储是指:该类型的集合数据元素可以直接通过下标(也即 index)来访问,

2、在 C#中有三种形式: Array(包括数组和List), string, struct。直接存储结构的优点是:向数据结构中添加元素是很高效的,只要直接放在数据末尾的第一个空位上就可以了。它的缺点是:向集合插入元素将会变得低效,它需要给插入的元素腾出位置并顺序移动后面的元素。 string 和 structs 虽然是直接存储结构,但它们与一般的集合定义有很大的不同,所以也不在本建议讨论之中。 在直接存储的数据结构中,需要区分的是数组和 List的选择。再次强调一下:如果集合的数目固定并且不涉及到转型,使用数组效率高,否则就使用 List。 顺序存储结构,也即线性表。线性表的大小可动态的扩大和缩

3、小,它在一片连续的区域中存储数据元素。线性表不能按照索引进行查找,它通过对地址的引用来搜索元素,为了找到某个元素,它必须遍历所有元素,直到找到对应的元素为止。所以线性表的优点是插入和删除数据效率高,而缺点是查找的效率相对来说低一些。 线性表又可以分为队列、栈以及索引群集,在 C#中,分别表现为: Queue, Stack,索引群集又进一步泛化为字典类型 Dictionary和双向链表 LinkedList。 队列 Queue遵循的是先入先出模式,它在集合末尾添加元素,在集合起始删除元素,如图: 队列操作 根据队列的特点,可以用来处理并发命令等场景:将所有客户端的命令先入队,由专门的工作线程来执

4、行队列的命令。在分布式中的消息队列就是一个典型的队列应用实例。 栈 Stack遵循的是后入先出模式,它在集合末尾添加元素,同时也在集合末尾删除元素,如图 2-3: 栈操作 字典 Dictionary存储的是键值对,值在基于键的散列码的基础上进行存储。字典类对象由包含集合元素的存储桶组成,每一存储桶与基于该元素的键的哈希值关联。如果需要根据键进行值的查找,使用 Dictionary将会使搜索和检索更会快捷。 双向链表 LinkedList是一个类型为 LinkedListNode 的元素对象的集合。当我们在集合中觉得插入和删除数据很慢的时候,我们可以考虑使用链表。如果我们使用 LinkedLis

5、t,我们会发现 此类型并没有其它集合普遍具有的 Add方法,取而代之的是 AddAfter、 AddBefore、AddFirst、 AddLast 等方法。双向链表中的每个节点都向前指向 Previous 节点,向后指向Next 节点。 以上讨论了线性集合,在 FCL 中,非线性集合实现的不多。非线性集合分为层次集合和组集合。层次集合,如树,在 FCL 中就没有实现。组集合,又分为集和图。集在 FCL 中实现为HashSet,而图在 FCL 中也没有对应实现。集的概念在本意上是指存放在集合中的元素是无序的且不能重复的。下图演示了集的用途: 集 操作 除了上面我们提到的集合类型,还有其他几个要

6、掌握的集合类型,它们是在实际应用中发展出来的对以上基础类型的扩展: SortedList, SortedDictionary,SortedSet。它们所扩展的对应类为 List, Dictionary, HashSet,作用是将原本无序排列的元素,变为有序排列。 除了排序上的需求增加了上面 3 个集合类,在命名空间 System.Collections.Concurrent下,还涉及几个多线程集合类 。它们主要是: ConcurrentBag对应 List,ConcurrentDictionary对应 Dictionary,ConcurrentQueue对应 Queue, ConcurrentStack对应 Stack。如果我们的集合被用于多线程应用中,可以使用这几个集合类型。关于集合的线程安全性,可以进一步查看MSDN。 本建议到此为止已经介绍了 FCL 中的大部分泛型集合类,为了对它们有更好的了解,最后我们给出一个主要集合类 的类图。实际工作中,应该根据需要选择合适的集合类。 FCL 集合类图

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。