一、综述:

Dictionary<TKey,TValue>是在 .NET Framework 2.0 版中是新增的。表示键值对的集合,Dictionary<TKey,TValue>类是作为一个哈希表来实现的,通过键来检索值的速度非常快(检索速度取决于为 TKey 指定的类型的哈希算法的质量),接近于 O(1),效率比List<T>高很多。

二、常用方法:

示例:

var  dict = new Dictionary<int, string>();
for (var i = ; i < ; i++)
{
dict[i] ="a"+i.ToString();
}

1. 获取值(TValue)

a. 利用键索引,字典中不存在该键时会抛出异常。

var rt1= dict[];

b. TryGetValue(Tkey,out TValue) 推荐使用,第一个参数是键,第二个是获取相关联的值。如果未找到键,获取适当的默认值;例如,为 int 类型为 0,bool为 false,引用类型为null,例如string。该方法返回类型为bool类型,找到并成功获取到值返回true,否则返回false。

string rt2;
var rtBool = dict.TryGetValue(, out rt2);

2. 获取其中的项(键值对)KeyValuePair<TKey, TValue>

a.  First(),属于扩展方法。 返回字典中的第一个匹配项,返回的结果是一个键值对。当没有找到匹配项的时候引发异常

var r3 = dict.First(j => j.Key == );

b.  FirstOrDefault(),属于扩展方法。返回字典中的第一个匹配项,结果也是一个键值对,没有找到匹配项时不引发异常,且返回一个默认的键值对。例如,TValue为 int 类型为 0,bool为 false,引用类型为null。这个与常规的返回值不一样,需要特别注意。

var r4 = dict.FirstOrDefault(j => j.Key == );

没有找到的返回结果

3. ContainsKey(TKey) 确定 Dictionary<TKey, TValue> 是否包含指定的键(TKey)。返回值类型为bool

var r5 = dict.ContainsKey();

4. ContainsValue(TValue) 确定 Dictionary<TKey, TValue> 是否包含特定值(TValue)。返回值类型为bool

var r6 = dict.ContainsValue("a1");

5. 新添加值 Add(TKey,TValue) ,没有返回值,如果插入失败(例如插入重复键)将引发异常。

dict.Add(, "a11");

需要注意的是利用dict[TKey]=TValue同样可以实现插入,但同时也是编辑。它等同于

if (dict.ContainsKey())
{
dict[] = "a11";//修改更新
}
else
{
dict.Add(,"a11");//插入添加
}

6. 删除 Remove(TKey),返回值为bool型。如果成功找到并移除该元素,则为 true;否则为 false。如果是循环查找删除,不可以使用foreach,应当使用for。否则可能会引发异常。

    var keyArray = dict.Keys.ToArray();
for (var i = ; i < keyArray.Length; i++)
{
if (dict[keyArray[i]].Contains("a"))
{
var r7 = dict.Remove(keyArray[i]);
}
}

7. 清空字典 Clear() ,没有参数,也没有返回值。该方法会把集合中的元素对其他对象的引用也被释放。 容量保持不变。此方法的运算复杂度为 O(n),其中 n 是字典的容量。

dict.Clear()

三、注:

1. Dictionary<TKey,TValue>中的任何键都必须是唯一的。

2. 键不能为空引用,但是如果值类型 TValue 为引用类型,该值则可以为空。

3. foreach 语句是对枚举数的包装,只允许该枚举数读取集合,而不允许对Dictionary<TKey,TValue>写入、删除。

4. 只要不修改该集合,Dictionary<TKey, TValue> 就可以同时支持多个阅读器。 即便如此,从头到尾对一个集合进行枚举本质上并不是一个线程安全的过程。 当出现枚举与写访问互相争用这种极少发生的情况时,必须在整个枚举过程中锁定集合。 若要允许多个线程访问集合以进行读写操作,则必须实现自己的同步。

C# .Net 中字典Dictionary<TKey,TValue>泛型类 学习浅谈的更多相关文章

  1. C#中数组、集合(ArrayList)、泛型集合List<T>、字典(dictionary<TKey,TValue>)全面对比

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

  2. C# 字典 Dictionary<Tkey,Tvalue>

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

  3. C#编程(五十三)----------字典Dictionary<TKey,TValue>

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

  4. C#字典 Dictionary<Tkey,Tvalue> 之线程安全问题 ConcurrentDictionary<Tkey,Tvalue> 多线程字典

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

  5. .NET中Dictionary<TKey, TValue>浅析

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

  6. Dictionary<TKey, TValue> 类

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

  7. .net框架-字典对象 Hashtable & Dictionary<TKey,TValue> & SortedList

    字典对象: 字典对象是表示键值对的集合 字典对象有Hashtable(.net 1.0)及其泛型版本Dictionary<TKey,TValue> 字典对象还包括SortedList及其泛 ...

  8. Dictionary<Tkey.TValue>与SortedList

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

  9. “线程安全的” Dictionary(TKey,TValue)

    这是一篇翻译,专门介绍Dictionary线程安全问题,原文网址如下 http://www.grumpydev.com/2010/02/25/thread-safe-dictionarytkeytva ...

随机推荐

  1. 第三章· Redis消息队列

    一.生产消费模型 二.Redis发布消息的两种模式

  2. CSS3文字、背景与列表

    一.文本相关属性 1.字体 (1)字体设置 在HTML中,字体通过<font face="字体名称">来设置.在CSS中字体通过font-family属性来控制,里面可 ...

  3. Android NDK(C++) 双进程守护

    双进程守护如果从进程管理器观察会发现新浪微博.支付宝和QQ等都有两个以上相关进程,其中一个就是守护进程,由此可以猜到这些商业级的软件都采用了双进程守护的办法. 什么是双进程守护呢?顾名思义就是两个进程 ...

  4. OOM实例

    1. 使用Executors.newFixedThreadPool()方法,当不断创建新任务,而任务执行速度比创建速度慢时,任务对象就会在任务队列里面排队,堆内存得不到释放,导致OOM: 2. 使用P ...

  5. JVM运行时内存组成分为一些线程私

    JVM运行时内存组成分为一些线程私有的,其他的是线程共享的. 线程私有 程序计数器:当前线程所执行的字节码的行号指示器. Java虚拟机栈:java方法执行的内存模型,每个方法被执行时都会创建一个栈帧 ...

  6. apache beam ElasticSearchIO 遇到异常后job中断执行 自己定制beam IO

    可以将 ElasticSearchIO.java 源码拷贝至自己的项目.改名为MyElasticSearchIO.java.自己定制实现.这时编译会遇到auto.value失败.在pom.xml中加入 ...

  7. 一篇文章了解云安全领域的新宠CCSK

    这是一个人人谈"云"."大数据"的时代,作为一个IT民工,如果与同行间聊天时,不谈及这方面的内容,有人可能会觉得你落伍了,跟不上这个时代了.随云计算.云存储之后 ...

  8. Python的编码和解码

    Python的编码和解码 在不同的国家,存在不同的文字,由于现在的软件都要做到国际化通用,所以必须要有一种语言或编码方式,来实现各种编码的解码,然后重新编码. 在西方国家,没有汉字,只有英文,所以最开 ...

  9. IIS虚拟目录内的视频文件访问出错:HTTP 错误 404.3 - Not Found 由于扩展配置问题而无法提供您请求的页面。如果该页面是脚本,请添加处理程序。如果应下载文件,请添加 MIME 映射。

    MIME类型就是设定某种扩展名的文件用一种应用程序来打开的方式类型,当该扩展名文件被访问的时候,浏览器会自动使用指定应用程序来打开.多用于指定一些客户端自定义的文件名,以及一些媒体文件打开方式. 我是 ...

  10. 剑指Offer_编程题_19

    题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2, ...