本文参考:http://www.cnblogs.com/linzheng/archive/2010/12/13/1904709.html
下面为示例源码,VS2008编译通过。
private void Form1_Load(object sender, EventArgs e)
{
LoadData();
GetKeyValue();
}
private void LoadData()
{
//实例化对象
Dictionary<int, string> dic = new Dictionary<int, string>();
//对象打点添加,键相当于找到对应值的唯一标识,所以不能重复,但是值可以重复
dic.Add(1, "c");
dic.Add(3, "a");
dic.Add(2, "b");
//提取元素的方法
string a = dic[1];
string b = dic[2];
string c = dic[3];
Console.WriteLine("------" + a + "," + b + "," + c);
//var result = from pair in dic orderby pair.Key select pair;
var result = from pair in dic orderby pair.Value select pair;
foreach (KeyValuePair<int, string> pair in result)
{
Console.WriteLine("------Key:{0},Value:{1}", pair.Key, pair.Value);
}
//查找
if (dic.ContainsKey(2))
{
string str = dic[2];
Console.WriteLine("------" + str);
}
if (dic.ContainsValue("b"))
{
Console.WriteLine("------it contains b ");
}
if (dic.Remove(1))
{
Console.WriteLine("------remove key 1");
}
}
/*
Dictionary的基本用法。假如
需求:现在要导入一批数据,这些数据中有一个称为公司的字段是我们数据库里已经存在了的,目前我们需要把每个公司名字转为ID后才存入数据库。
分析:每导一笔记录的时候,就把要把公司的名字转为公司的ID,这个不应该每次都查询一下数据库的,因为这太耗数据库的性能了。
解决方案:在业务层里先把所有的公司名称及相应的公司ID一次性读取出来,然后存放到一个Key和Value的键值对里,
然后实现只要把一个公司的名字传进去,就可以得到此公司相应的公司ID,就像查字典一样。对,我们可以使用字典Dictionary操作这些数据。
示例:SetKeyValue()方法相应于从数据库里读取到了公司信息。
*/
/// <summary>
/// 定义Key为string类型,Value为int类型的一个Dictionary
/// </summary>
/// <returns></returns>
protected Dictionary<string, int> SetKeyValue()
{
Dictionary<string, int> dic = new Dictionary<string, int>();
dic.Add("公司1", 1);
dic.Add("公司2", 2);
dic.Add("公司3", 3);
dic.Add("公司4", 4);
return dic;
}
/// <summary>
/// 得到根据指定的Key行到Value
/// </summary>
protected void GetKeyValue()
{
Dictionary<string, int> myDictionary = SetKeyValue();
//测试得到公司2的值
int directorValue = myDictionary["公司2"];
Console.WriteLine("------公司2的value是:" + directorValue.ToString());
}
输出为:
------c,b,a
------Key:3,Value:a
------Key:2,Value:b
------Key:1,Value:c
------b
------it contains b
------remove key 1
------公司2的value是:2