C# .Net 中字典Dictionary<TKey,TValue>泛型类 学习浅谈
一、综述:
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>泛型类 学习浅谈的更多相关文章
- C#中数组、集合(ArrayList)、泛型集合List<T>、字典(dictionary<TKey,TValue>)全面对比
C#中数组.集合(ArrayList).泛型集合List<T>.字典(dictionary<TKey,TValue>)全面对比 为什么把这4个东西放在一起来说,因为c#中的这4 ...
- C# 字典 Dictionary<Tkey,Tvalue>
最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来.我们都知道计算机技术发展日新月异,速度惊人的快,你我稍不留神,就会被慢慢淘汰!因此:每日不间断的学习是避免被 ...
- C#编程(五十三)----------字典Dictionary<TKey,TValue>
字典 关键字:Dicitionary 说明: 必须包含命名空间System.Collection.Generic Dictionary里面的每一个元素都是一个键值对(由两个元组组成:键和值). 键必须 ...
- C#字典 Dictionary<Tkey,Tvalue> 之线程安全问题 ConcurrentDictionary<Tkey,Tvalue> 多线程字典
ConcurrentDictionary<Tkey,Tvalue> Model #region 程序集 mscorlib, Version=4.0.0.0, Culture=neutra ...
- .NET中Dictionary<TKey, TValue>浅析
.NET中Dictionary<TKey, Tvalue>是非常常用的key-value的数据结构,也就是其实就是传说中的哈希表..NET中还有一个叫做Hashtable的类型,两个类型都 ...
- Dictionary<TKey, TValue> 类
C# Dictionary<TKey, TValue> 类 Dictionary<TKey, TValue> 泛型类提供了从一组键到一组值的映射.字典中的每个添加项都由一个值及 ...
- .net框架-字典对象 Hashtable & Dictionary<TKey,TValue> & SortedList
字典对象: 字典对象是表示键值对的集合 字典对象有Hashtable(.net 1.0)及其泛型版本Dictionary<TKey,TValue> 字典对象还包括SortedList及其泛 ...
- Dictionary<Tkey.TValue>与SortedList
一.概述 表示Key/Value集合,可以添加删除元素,允许按Key来访问元素.是Hashtable的泛型等效类. 它需要一个相等实现来确定键是否相等,可以使用实现了IEqualityComparer ...
- “线程安全的” Dictionary(TKey,TValue)
这是一篇翻译,专门介绍Dictionary线程安全问题,原文网址如下 http://www.grumpydev.com/2010/02/25/thread-safe-dictionarytkeytva ...
随机推荐
- 清北学堂part1
睡眠质量相当高的一天(滑稽) 整一整都学了啥 1:高精度(相当水,毕竟学过) 2:模运算(?! 这还要讲?) 3:快速幂(还要谢一位学习高数时间为我们讲解的同学...不得不说真的有效,快速幂已经是随手 ...
- [模板] 虚树 && bzoj2286-[Sdoi2011]消耗战
简介 虚树可以解决一些关于树上一部分节点的问题. 对于一棵树 \(T\) 的一个子集 \(S\), 可以在 \(O(|S| \log |S|)\) 的时间复杂度内求出 \(S\) 的虚树. 虚树包括根 ...
- kafka 发送确认参数acks的几种模式
1. acks=0 意味着生产者能够通过网络吧消息发送出去,那么就认为消息已成功写入Kafka 一定会丢失一些数据 2. acks=1 意味着首领在疏导消息并把它写到分区数据问津是会返回确认或者错误响 ...
- 从Java角度修复SQL注入漏洞
很多情况因为过滤不严导致很多网站存在sql注入,这里以用户登陆为例,简单举例 首先创建一个测试的数据库 比较基础,不写创建过程了 java代码如下: package cn.basic.jdbc; im ...
- Security+认证812分轻松考过(备战分享)
2019.02.12,开工第一天,我参加了security+考试并顺利通过了考试,812分的成绩有点出乎我的意料,据我所知我周围还没有人考过800分的.怀着愉悦的心态分享下我的备考经历和考试经验. 备 ...
- JS学习笔记Day10
一.设置或获取元素对象中(标签中)的属性和自定义属性 对象.属性 对象['属性'] 对象.getAttribute('属性名') 对象.setAttribute('属性名','属性值'); 对象.re ...
- 安装python caffe过程中遇到的一些问题以及对应的解决方案
关于系统环境: Ubuntu 16.04 LTS cuda 8.0 cudnn 6.5 Anaconda3 编译pycaffe之前需要配置文件Makefile.config ## Refer to h ...
- Linux性能优化实战:系统的swap变高(08)
一.Swap 原理 前面提到,Swap 说白了就是把一块磁盘空间或者一个本地文件(以下讲解以磁盘为例),当成内存来使用.它包括换出和换入两个过程 1.所谓换出 就是把进程暂时不用的内存数据存储到磁盘中 ...
- Visual Studio图形调试器详细使用教程(基于DirectX11)
前言 对于DirectX程序开发者来说,学会使用Visual Studio Graphics Debugger(图形调试器)可以帮助你全面了解渲染管线绑定的资源和运行状态,从而确认问题所在.现在就以我 ...
- SQLMAP注入教程-11种常见SQLMAP使用方法详解
sqlmap也是渗透中常用的一个注入工具,其实在注入工具方面,一个sqlmap就足够用了,只要你用的熟,秒杀各种工具,只是一个便捷性问题,sql注入另一方面就是手工党了,这个就另当别论了.今天把我一直 ...