zoukankan      html  css  js  c++  java
  • C#中Dictionary的用法及用途实例

    Dictionary<string, string>是一个泛型 

    他本身有集合的功能有时候可以把它看成数组 

    他的结构是这样的:Dictionary<[key], [value]> 

    他的特点是存入对象是需要与[key]值一一对应的存入该泛型 

    通过某一个一定的[key]去找到对应的值 

    举个例子: 

    //实例化对象 

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

    //对象打点添加 

    dic.Add(1, "one"); 

    dic.Add(2, "two"); 

    dic.Add(3, "one"); 

    //提取元素的方法 

    string a = dic[1]; 

    string b = dic[2]; 

    string c = dic[3]; 

    //1、2、3是键,分别对应“one”“two”“one” 

    //上面代码中分别把值赋给了a,b,c 

    //注意,键相当于找到对应值的唯一标识,所以不能重复 

    //但是值可以重复 

    如果你还看不懂我最后给你举一个通俗的例子 

    有一缸米,你想在在每一粒上都刻上标记,不重复,相当于“键”当你找的时候一一对应不会找错,这就是这个泛型的键的-作用,而米可以一样,我的意思你明白了吧?

    -------------------------------------------------------------------------

    c# 对dictionary类进行排序用什么接口实现

    如果使用.Net Framework 3.5的话,事情就很简单了。呵呵。 

    如果不是的话,还是自己写排序吧。 

    1 using System;
    2
    3  using System.Collections.Generic;
    4
    5 using System.Text;
    6
    7 using System.Linq;
    8
    9
    10
    11 namespace DictionarySorting
    12
    13 {
    14
    15 class Program
    16
    17 {
    18
    19 static void Main(string[] args)
    20
    21 {
    22
    23 Dictionary<int, string> dic = new Dictionary<int, string>();
    24
    25 dic.Add(1, "HaHa");
    26
    27 dic.Add(5, "HoHo");
    28
    29 dic.Add(3, "HeHe");
    30
    31 dic.Add(2, "HiHi");
    32
    33 dic.Add(4, "HuHu");
    34
    35
    36
    37 var result = from pair in dic orderby pair.Key select pair;
    38
    39
    40
    41 foreach (KeyValuePair<int, string> pair in result)
    42
    43 {
    44
    45 Console.WriteLine("Key:{0}, Value:{1}", pair.Key, pair.Value);
    46
    47 }
    48
    49
    50
    51 Console.ReadKey();
    52
    53 }
    54
    55 }
    56
    57 }
    58
    59

    【执行结果】 

    1 Key:1, Value:HaHa
    2
    3 Key:2, Value:HiHi
    4
    5 Key:3, Value:HeHe
    6
    7 Key:4, Value:HuHu
    8
    9 Key:5, Value:HoHo

    Dictionary的基本用法。假如

    需求:现在要导入一批数据,这些数据中有一个称为公司的字段是我们数据库里已经存在了的,目前我们需要把每个公司名字转为ID后才存入数据库。

    分析:每导一笔记录的时候,就把要把公司的名字转为公司的ID,这个不应该每次都查询一下数据库的,因为这太耗数据库的性能了。

    解决方案:在业务层里先把所有的公司名称及相应的公司ID一次性读取出来,然后存放到一个Key和Value的键值对里,然后实现只要把一个公司的名字传进去,就可以得到此公司相应的公司ID,就像查字典一样。对,我们可以使用字典Dictionary操作这些数据。

    示例:SetKeyValue()方法相应于从数据库里读取到了公司信息。

    1 /// <summary>
    2 /// 定义Key为string类型,Value为int类型的一个Dictionary
    3 /// </summary>
    4 /// <returns></returns>
    5 protected Dictionary<string, int> SetKeyValue()
    6 {
    7 Dictionary<string, int> dic = new Dictionary<string, int>();
    8 dic.Add("公司1", 1);
    9 dic.Add("公司2", 2);
    10 dic.Add("公司3", 3);
    11 dic.Add("公司4", 4);
    12 return dic;
    13 }
    14
    15
    16 /// <summary>
    17 /// 得到根据指定的Key行到Value
    18 /// </summary>
    19 protected void GetKeyValue()
    20 {
    21 Dictionary<string, int> myDictionary = SetKeyValue();
    22 //测试得到公司2的值
    23 int directorValue = myDictionary["公司2"];
    24 Response.Write("公司2的value是:" + directorValue.ToString());
    25 }
  • 相关阅读:
    高精度减法
    HDU 4460 Friend Chains
    POJ 2386 Lake Counting
    POJ 1852 Ants
    HDU 1240 Asteroids!
    SQL注入之Sqli-labs系列第三十六关(基于宽字符逃逸GET注入)和三十七关(基于宽字节逃逸的POST注入)
    SQL注入之Sqli-labs系列第三十四关(基于宽字符逃逸POST注入)和三十五关
    SQL注入之Sqli-labs系列第三十三关(基于宽字符逃逸注入)
    SQL注入之Sqli-labs系列第三十关(基于WAF防护的双引号报错注入)和三十一关
    墨者-uWSGI 漏洞复现(CVE-2018-7490)
  • 原文地址:https://www.cnblogs.com/moss_tan_jun/p/2014131.html
Copyright © 2011-2022 走看看