Dictionary基础定义:

  1. 从一组键(key)到一组值(value)的映射,每一个添加项都是由一个值及其相关联的键组成;
  2. 任何键都必须是唯一的;
  3. 键不能为空引用的null(VB中的Nothing),若值为引用类型,则可以为空;
  4. key 和value可以是任何类型(int,string,bool等);

Demo:key为int类型,值为string类型

初始化

  Dictionary<int,string> dic=new Dictionary<int,string>();

添加元素 

  dic.Add(1,"C#");

  dic.Add(2,"Java");

通过key查找元素

  if(dic.ContainsKey(1))

    {

    key(主键)=1;

    value(数据列)=dic[1];

   }

通过keyValuePair遍历元素

  foreach(keyValuePair<int,string>kvp in dic)

  {

    Console.WriteLine("key={0},value{1}",kvp.key,key.value);

    key(主键)=kvp.key;

    key(数据列)=kvp.value;

  }

近遍历键keys属性

  Dictionary<int,string>.keyConllection keycol=dic.keys;

  foreach(int key in keycol)

  {

    key(主键)=key;

  }

仅遍历values属性

  Dictionary<int,string>.ValueConllection valcol=dic.values;

  foreach(string value in valcol)

  {

    value(数据列值)=value;

  }

通过Remove方法移除指定的键值

  dic.Remove(1);

   if(dic.ContainsKey(1))

   {

    key=1;

    value=key[1]

   }

   else  {

   Console.WriteLine("不存在key:1");

}

Dictionary常用属性和方法:

  1. Comparer:获取用于确定字典中的键是否相等的IEqualityComparer;
  2. Count:获取包含在Dictionary中的键/值对的总数;
  3. Item:获取或设置与指定的键相关联的值;
  4. keys:获取包含Dictionary中键的集合;
  5. values:获取包含Dictionary中值的集合;
  6. Add:将指定的键和值添加到字典中;
  7. Clear:从Dictionary中移除所有的键和值;
  8. ContainsKey:确定Dictionary是否包含指定的键;
  9. ContainsValue:确定Dictionary是否包含特定值;
  10. GetEnumerator:返回循环访问Dictionary的枚举数;
  11. GetType:获取当前实例的type(从object继承);
  12. Remove:从Dictionary中移除所指定的键的值;
  13. Tostring:返回表示当前Object的string(从object继承);
  14. TryGetValue:获取与指定的键相关联的值;

Dictionary集合运用的更多相关文章

  1. C#Dictionary集合的使用

    题目:输入一串字符串字母,比如:Welcome to China,比较每个字母出现的次数,不区分大小写. 解决这道题的方法很多.可能一百个人有一百个思路.当时第一眼看到这个题我的思路是:先将接受的一串 ...

  2. Collection was modified; enumeration operation may not execute Dictionary 集合已修改;可能无法执行枚举操作

    public void ForeachDic() { Dictionary dic = new Dictionary(); dic.Add("1", 10); dic.Add(&q ...

  3. Dictionary集合 字典

    1 Dictionary<int, string> dic = new Dictionary<int, string>(); dic.Add(,"张三"); ...

  4. C#泛型集合之Dictionary<k, v>使用技巧

    1.要使用Dictionary集合,需要导入C#泛型命名空间 System.Collections.Generic(程序集:mscorlib) 2.描述 1).从一组键(Key)到一组值(Value) ...

  5. ASP.NET MVC中默认Model Binder绑定Action参数为List、Dictionary等集合的实例

    在实际的ASP.NET mvc项目开发中,有时会遇到一个参数是一个List.Dictionary等集合类型的情况,默认的情况ASP.NET MVC框架是怎么为我们绑定ASP.NET MVC的Actio ...

  6. C#泛型集合—Dictionary<K,V>使用技巧

    转载:http://blog.csdn.net/a125138/article/details/7742022 1.要使用Dictionary集合,需要导入C#泛型命名空间 System.Collec ...

  7. 转载C#泛型集合—Dictionary<K,V>使用技巧

    1.要使用Dictionary集合,需要导入C#泛型命名空间 System.Collections.Generic(程序集:mscorlib) 2.描述 1).从一组键(Key)到一组值(Value) ...

  8. 使用Dictionary泛型集合封装业务逻辑判断 z

    C#2.0 提供了Dictionary 泛型类,它提供了从一组键到一组值的映射.字典中的每个添加项都由一个值及其相关联的键组成.通过键来检索值的速度是非常快的,接近于 O(1),这是因为 Dictio ...

  9. 04.Dictionary字典键值对集合

    Dictionary字典键值对集合和Hashtable键值对集合的功能非常类似, 只是在声明的时候,必须为其制定值的类型. 示例代码: namespace _11.Dictionary字典集合的学习 ...

随机推荐

  1. 信息安全之路-web-xss学习(3)

    DOM型xss DOM型xss属于在客户端执行的xss,并不经过服务端解析.测试过程如下 Low型: 源代码: <script> if (document.location.href.in ...

  2. Predict Referendum by sklearn package

    Background Last day we talk about Python Basics in Chinese. Today, we will do data analysis with pyt ...

  3. GTID做mysql主从时报错

    今天在做主从同步时,显示slave_IO线程为NO ,并且报如下错误 Slave_IO_Running: No ... Last_IO_Error: Fatal error: The slave I/ ...

  4. IDEA Maven项目的Mybatis逆向工程

    IDEA Maven项目的Mybatis逆向工程 1.配置.pom 如果是在多模块开发下,该文件逆向工程要生成的那个模块下的pom文件. <build> <plugins> & ...

  5. 【Core】当前 .NET SDK 不支持将 .NET Core 2.2 设置为目标。请将 .NET Core 2.1 或更低版本设置

    问题起因: 新的电脑,打开core2.2的项目时,因为没有安装2.2 sdk,项目编译失败 所以在选择目标框架下拉框选择安装其他目标框架 会跳转到官网下载sdk:https://dotnet.micr ...

  6. 修改Ubuntu锁屏快捷键

    修改为Win + L. 避免与Phpstorm中的代码格式化冲突.

  7. 谈谈传统BIO网络编程模型的局限性与NIO

    先来看看我们的server端: 创建一个serversocket,进行监听,每来一个客户端,就启动一个新启动为其服务: private void createListenSocket() { //如果 ...

  8. LineRenderer实现一个画线组件

    using System; using UnityEngine; class UILine { GameObject targetObj; LineRenderer lineRenderer; //L ...

  9. session和cookie的简介

    Session(时域)在计算机中,尤其是在网络应用中,称为“会话控制”.Session 对象存储特定用户会话所需的属性及配置信息.这样,当用户在应用程序的 Web 页之间跳转时,存储在 Session ...

  10. [GXOI/GZOI2019]旅行者

    就我感觉这道题很神仙吗/kel 仔细想想应该也是一种适用范围挺广的做法. 考虑我们可以通过dijkstra在O(nlogn)求出一个点集到另外一个点集的最短路. 那么我们可以通过一些划分点集的方式使得 ...