.net框架-字典对象 Hashtable & Dictionary & SortedList

时间:2023-01-27 07:25:55

字典对象:

  字典对象是表示键值对的集合

  字典对象有Hashtable(.net 1.0)及其泛型版本Dictionary<TKey,TValue>

  字典对象还包括SortedList及其泛型版本SortedList<TKey,TValue>(SortedList按键进行排序)

  字典对象实现了接口:IDictionary, ICollection, IEnumerable, ICloneable (泛型实现了IDictionary, ICollection, IEnumerable对应的泛型接口)

IDictionary接口:

  object this[object key] {get;set;}  

  ICollection Keys {get;set;}

  ICollection Values {get;set;}

  void Add(object key, object value)

  void Remove (object key)

  object Contains(object key)

IDictionary<TKey, TValue>接口:

  (1)与IDictionary相同的:

    TValue this[TKey] {get;set;}  

    void Add(TKey,TValue)

    .........  (其它同IDictionary接口略,其它形式均为泛型T占位符参数代替Object参数)

  (2)与IDictionary不同的:

    bool ContainsKey(TKey)

    bool TryGetValue(TKey, out TValue value)

区别:

  Hastable 和 Dictionary<TKey,TValue>,前者是.net1.0下的字典对象,后者是前者泛型版本 ,泛型减少了装、拆箱和强制转换,效率更高

  SortedList 和 SortedList<TKey,TValue>,按键序存储的字典对象

  Hastable和SortedList,前进自然存储、后者按键序存储,故前者插入快,查找慢,后者反之。

  

参考:

  http://www.cnblogs.com/xqhppt/archive/2011/09/15/2178101.html

.net框架-字典对象 Hashtable & Dictionary<TKey,TValue> & SortedList的更多相关文章

  1. 泛型与非泛型集合类的区别及使用例程,包括ArrayList,Hashtable,List&lt&semi;T&gt&semi;,Dictionary&lt&semi;Tkey&comma;Tvalue&gt&semi;,SortedList&lt&semi;Tkey&comma;Tvalue&gt&semi;,Queue&lt&semi;T&gt&semi;,Stack&lt&semi;T&gt&semi;等

    泛型与非泛型集合类在C#程序中是非常重要的一个基础概念,这里列一个表来进行对比: 非泛型集合类 泛型集合类 描述 ArrayList List<T> 表示具有动态大小的对象数组 Hasht ...

  2. C&num; 字典 Dictionary&lt&semi;Tkey&comma;Tvalue&gt&semi;

    最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来.我们都知道计算机技术发展日新月异,速度惊人的快,你我稍不留神,就会被慢慢淘汰!因此:每日不间断的学习是避免被 ...

  3. C&num; &period;Net 中字典Dictionary&lt&semi;TKey&comma;TValue&gt&semi;泛型类 学习浅谈

    一.综述: Dictionary<TKey,TValue>是在 .NET Framework 2.0 版中是新增的.表示键值对的集合,Dictionary<TKey,TValue&g ...

  4. C&num;编程(五十三)----------字典Dictionary&lt&semi;TKey&comma;TValue&gt&semi;

    字典 关键字:Dicitionary 说明: 必须包含命名空间System.Collection.Generic Dictionary里面的每一个元素都是一个键值对(由两个元组组成:键和值). 键必须 ...

  5. C&num;字典 Dictionary&lt&semi;Tkey&comma;Tvalue&gt&semi; 之线程安全问题 ConcurrentDictionary&lt&semi;Tkey&comma;Tvalue&gt&semi; 多线程字典

    ConcurrentDictionary<Tkey,Tvalue>  Model #region 程序集 mscorlib, Version=4.0.0.0, Culture=neutra ...

  6. C&num;中数组、集合(ArrayList)、泛型集合List&lt&semi;T&gt&semi;、字典&lpar;dictionary&lt&semi;TKey&comma;TValue&gt&semi;&rpar;全面对比

    C#中数组.集合(ArrayList).泛型集合List<T>.字典(dictionary<TKey,TValue>)全面对比 为什么把这4个东西放在一起来说,因为c#中的这4 ...

  7. Dictionary&lt&semi;Tkey&period;TValue&gt&semi;与SortedList

    一.概述 表示Key/Value集合,可以添加删除元素,允许按Key来访问元素.是Hashtable的泛型等效类. 它需要一个相等实现来确定键是否相等,可以使用实现了IEqualityComparer ...

  8. &period;NET中Dictionary&lt&semi;TKey&comma; TValue&gt&semi;浅析

    .NET中Dictionary<TKey, Tvalue>是非常常用的key-value的数据结构,也就是其实就是传说中的哈希表..NET中还有一个叫做Hashtable的类型,两个类型都 ...

  9. Dictionary&lt&semi;TKey&comma; TValue&gt&semi; 类

    C# Dictionary<TKey, TValue> 类 Dictionary<TKey, TValue> 泛型类提供了从一组键到一组值的映射.字典中的每个添加项都由一个值及 ...

随机推荐

  1. IDE:IDEA Commit Changes Dialog local changes refresh

    IDEA提交代码,一直卡着不动,显示:Commit Changes Dialog local changes refresh 修改方法为: go to settings - version contr ...

  2. git 上的pull request 是什么意思?

    1.git 上有常见的pull request 功能 2.pull request 的含义 解释一:    有一个仓库,叫Repo A.你如果要往里贡献代码,首先要Fork这个Repo,于是在你的Gi ...

  3. 32、shiro框架入门3&period;授权

    一. 授权,也叫访问控制,即在应用中控制谁能访问哪些资源(如访问页面/编辑数据/页面操作等).在授权中需了解的几个关键对象:主体(Subject).资源(Resource).权限(Permission ...

  4. adb不响应

    1.CMD命令窗口输入:adb nodaemon server .然后就会提示你哪个端口被占用了. 2.输入netstat -ano | findstr "5037" .然后会弹出 ...

  5. 配置iSCSI

    先查下yum list | grep iscsi, 存在iscsi包, 进行安装:yum install iscsi-initiator-utils.x86_64, cat /etc/iscsi/in ...

  6. Qt实战之开发CSDN下载助手 (3)(结束篇)

    再次申明下,开发这款助手,主要是用来学习交流,并不是用来开发什么刷积分的软件. 好了,言归正传,这次,主要的分析下CSDN的下载,评论,验证码获取机制等等. 好,回到第二篇,当我们成功登陆时,CSDN ...

  7. poj 2299 Ultra-QuickSort(树状数组求逆序数&plus;离散化)

    题目链接:http://poj.org/problem?id=2299 Description In this problem, you have to analyze a particular so ...

  8. JS所包含的大纲内容,以及JS中数据类型、运算符的介绍

    JavaSctipt javascript:1.特效2.表单验证 原理:何时?1.找到标签 何时?2.操作标签 写在那里? 内联(行内)(不推荐直接写js代码,经常写方法调用) 写在标签里面,以属性的 ...

  9. 1&period;1初识python

    1.目前大量的公司都在使用python,功能强大很是牛逼! 2.运维要懂开发,做个全栈的工程师贼牛逼 3.python是一个解释型语言,编译型和解释型的区别是: ①编译型语言由编译器(Compiler ...

  10. 【cocos2dx中Node类getParent和getChildByTag&lpar;&rpar;】学习体会

    參考http://cn.cocos2d-x.org/doc/cocos2d-x-3.0/d3/d82/classcocos2d_1_1_node.html 当中和child.parent有关的成员函数 ...