关于C#中字典Dictionary的顺序及倒序详解

C# .net 3.5 以上的版本引入 Linq 后,字典Dictionary排序变得十分简单,用一句类似 sql 数据库查询语句即可搞定;不过,.net 2.0 排序要稍微麻烦一点,为便于使用,将总结 .net 3.5 和 2.0 的排序方法。

一、创建字典Dictionary 对象

  假如 Dictionary 中保存的是一个网站页面流量,key 是网页名称,值value对应的是网页被访问的次数,由于网页的访问次要不断的统计,所以不能用 int 作为 key,只能用网页名称,创建 Dictionary 对象及添加数据代码如下:

Dictionary dic = new Dictionary();  dic.Add("index.html", 50);  dic.Add("product.html", 13);  dic.Add("aboutus.html", 4);  dic.Add("online.aspx", 22);  dic.Add("news.aspx", 18);

登录后复制

 二、.net 3.5 以上版本 Dictionary排序(即 linq dictionary 排序)

  1、dictionary按值value排序

 private void DictonarySort(Dictionary dic)  {    var dicSort = from objDic in dic orderby objDic.Value descending select objDic;    foreach(KeyValuePair kvp in dicSort)      Response.Write(kvp.Key + ":" + kvp.Value + "
");  }

登录后复制

 排序结果:

  index.html:50
  online.aspx:22
  news.aspx:18
  product.html:13
  aboutus.html:4

  上述代码是按降序(倒序)排列,如果想按升序(顺序)排列,只需要把变量 dicSort 右边的 descending 去掉即可。

  2、C# dictionary key 排序

  如果要按 Key 排序,只需要把变量 dicSort 右边的 objDic.Value 改为 objDic.Key 即可。

三、.net 2.0 版本 Dictionary排序

  1、dictionary按值value排序(倒序)

private void DictionarySort(Dictionary dic)  {    if (dic.Count > 0)    {      List> lst = new List>(dic);      lst.Sort(delegate(KeyValuePair s1, KeyValuePair s2)      {        return s2.Value.CompareTo(s1.Value);      });      dic.Clear();      foreach (KeyValuePair kvp in lst)        Response.Write(kvp.Key + ":" + kvp.Value + "
");    }  }

登录后复制

排序结果:

  index.html:50
  online.aspx:22
  news.aspx:18
  product.html:13
  aboutus.html:4

  顺序排列:只需要把变量 return s2.Value.CompareTo(s1.Value); 改为 return s1.Value.CompareTo(s2.Value); 即可。

2、C# dictionary key 排序(倒序、顺序)

  如果要按 Key 排序,倒序只需把 return s2.Value.CompareTo(s1.Value); 改为 return s2.Key.CompareTo(s1.Key);;顺序只需把return s2.Key.CompareTo(s1.Key); 改为 return s1.Key.CompareTo(s2.Key); 即可。

以上就是关于C#中字典Dictionary的顺序及倒序详解的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2443020.html

(0)
上一篇 2025年3月3日 13:55:58
下一篇 2025年2月27日 17:25:07

AD推荐 黄金广告位招租... 更多推荐

发表回复

登录后才能评论