这个系列我们看看C#中有哪些我们知道。可是又不知道怎么用。又或者懒得去了解的东西,比方这篇我们要介绍的toDictionary

和ToLookup。

  从图中我们看到有四个ToXXX的方法,当中ToArray和ToList。我想大家用的是很许多,可是ToDictionary和ToLookup

不见得有多少人用了,但不是否能认的是这些方法确实非常实用。

不多废话了。直接如主题,我们有这种一个实体,包括:票号,订单号,备注。

    class Ticket
{
/// <summary>
/// 票号
/// </summary>
public string TicketNo { get; set; } /// <summary>
/// 订单号
/// </summary>
public int OrderID { get; set; } /// <summary>
/// 备注
/// </summary>
public string Description { get; set; }
}

好了。我们看看需求,票号和订单号是一对多的关系,也就是说一个订单号可能包括几个票号,每一个票号都有自己相应的状态。

比方票号有 “改签”,"未使用",“成交”,"退票" 等等,以下我们灌一批数据进去。

        public static List<Ticket> GetList()
{
return new List<Ticket>()
{
new Ticket(){ TicketNo="999-12311",OrderID=79121281,Description="改签"},
new Ticket(){ TicketNo="999-24572",OrderID=29321289,Description="退票"},
new Ticket(){ TicketNo="999-68904",OrderID=19321289,Description="成交"},
new Ticket(){ TicketNo="999-24172",OrderID=64321212,Description="未使用"},
new Ticket(){ TicketNo="999-24579",OrderID=19321289,Description="退票"},
new Ticket(){ TicketNo="999-21522",OrderID=79121281,Description="未使用"},
new Ticket(){ TicketNo="999-24902",OrderID=79121281,Description="退票"},
new Ticket(){ TicketNo="999-04571",OrderID=29321289,Description="改签"},
new Ticket(){ TicketNo="999-23572",OrderID=96576289,Description="改签"},
new Ticket(){ TicketNo="999-24971",OrderID=99321289,Description="成交"}
};
}

举个样例: 我须要统计各个订单号中的票号情况。

  

非常明显。这是一个分组排序的问题,可能你立即就想起了groupby来实现。当然groupby是能够实现的,只是groupby不能算是一种数据

结构,不能带有索引。没有字典那样easy输出和操作。

方案一: 採用普通的foreach循环。

普通情况下,可能有一部分人都採用这样的原始的方法。将list数据通过foreach循环放到dictionary中,就是代码写的多一些,也算

是最灵活的。

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

            foreach (var item in ticketlist)
{
if (!dic.ContainsKey(item.OrderID))
{
dic.Add(item.OrderID, item);
}
else
{
dic[item.OrderID] = item;
}
}

方案二:使用ToDictionary

  

  

    

从图中我们能够看到。发生悲剧的异常了。我们知道dictionary中key是不能反复的。然而ToDictionary中并没有给我们做

key的反复值推断,那也就側面说明ToDictionary在kv中仅仅能是 “一对一”的关系,也就是v中永远仅仅会有一条记录。显然这不是

我须要的,在了解ToDictionary原理后,该方案失败。

方案三: 使用ToLookup

  

  或许微软知道客户有这么个需求。就採用了一个ToDictionary的加强版,你也能够觉得是一种新的字典数据结构。它就避免了这

种“一对一”的关系,採用“一对多”的实现。

            var dic = ticketlist.ToLookup(i => i.OrderID);

            foreach (var item in dic)
{
Console.WriteLine("订单号:" + item.Key); foreach (var item1 in item)
{
Console.WriteLine("\t\t" + item1.TicketNo + " " + item1.Description);
}
}

并且ToLookup和字典一样,是带有索引形式。这个groupby就不具备了,当然Tolookup另一个强大的功能,就是使用

Func<TSource, TElement> elementSelector来对如今的v元素进行转换来避免我刚才  Console.WriteLine("\t\t" + item1.

TicketNo + "  " + item1.Description);语句

好了。大概就这样了,赶紧停笔,不说了。。。妹子催着要去顾村公园。

o(∩_∩)o

挖一挖C#中那些我们不经常使用的东西之系列(1)——ToDictionary,ToLookup的更多相关文章

  1. 挖一挖C#中那些我们不经常使用的东西之系列(4)——GetHashCode,ExpandoObject

    一:GetHashCode 从MSDN上能够看到的解释是:用作特定类型的哈希函数,也就是说不论什么对象的实例都会有一个int32类型的HashCode.而且存放在FCL中的 HashCollectio ...

  2. 挖一挖C#中那些我们不常用的东西之系列(3)——StackTrace,Trim

    时间太快了,三月又要过去了,告别一下...继续期待生死未卜的四月,今天我们继续挖一挖. 一: Environment.StackTrace 可能我们看到最多的就是catch中的e参数,里面会有一个St ...

  3. 挖一挖不常用到而又很实用的重载-Trim

    这个我想没有那个开发人员说不知道,但是里面有一个重载,这个不知道有多少开发人员知道! 可以看到,我可以去掉字符串前后的指定字符,只要我在char[]中指定即可,而不是仅仅去掉空格,这次为什么要提它,是 ...

  4. 挖一挖@Bean这个东西

    有Bean得治 任何一个正常程序的访问都会在内存中创建非常多的对象,对象与对象之间还会出现很多依赖关系(一个处理业务逻辑的类中几乎都会使用到别的类的实例),一般的做法都是使用new关键字来创建对象,对 ...

  5. 挖一挖不常用到而又很实用的重载-Split

    Split这个基本上所有的程序开发人员都用到,一般使用单字符和长字符串拆分字符串的较多,其实还有一个重载非常好用,那就是多种组合字符来进行拆分. 例如: "aaaaaaaaaa{@}bbbb ...

  6. ArcGIS案例学习笔记-批处理擦除挖空挖除相减

    ArcGIS案例学习笔记-批处理擦除挖空挖除相减 联系方式:谢老师,135-4855-4328,xiexiaokui#qq.com 目的:批处理擦除.挖空.挖除.相减 数据源:chp13/ex5/pa ...

  7. ArcGIS案例学习笔记-手动编辑擦除挖空挖除相减

    ArcGIS案例学习笔记-手动编辑擦除挖空挖除相减 联系方式:谢老师,135-4855-4328,xiexiaokui#qq.com 目的:手动编辑擦除.挖空.挖除.相减 1. 选中内部要素 2. c ...

  8. 挖一挖不经常使用到而又非常有用的重载-Split

    Split这个基本上全部的程序开发者都用到,一般使用单字符和长字符串拆分字符串的较多.事实上另一个重载很好用.那就是多种组合字符来进行拆分. 比如: "aaaaaaaaaa{@}bbbbbb ...

  9. Spring Web MVC中的页面缓存支持 ——跟我学SpringMVC系列

    Spring Web MVC中的页面缓存支持 ——跟我学SpringMVC系列

随机推荐

  1. dict的setdefault(学习bottle源代码)

    在bottle的源代码中,看到如下一段话: sys.modules.setdefault('bottle', sys.modules['__main__']) 这段话,实际上就是dict类型的setd ...

  2. Disruptor源码分析

    本文将介绍Disruptor的工作机制,并分析Disruptor的主要源码 基于的版本是3.3.7(发布于2017.09.28) 水平有限,如有谬误请留言指正 0. 什么是Disruptor? Dis ...

  3. zabbix监控web应用

    1)web应用监控介绍 使用zabbix自带的web场景可以监控url的状态码,响应时间,url的下载速度,非常的棒 思路:定义模板-->创建应用集--->定义web场景--->定义 ...

  4. 从dao层查出的数据到页面时数值都是零的异常

    异常问题: IllegalArgumentException: argument type mismatch at cn.tedu.utils.BeanListHandler.handle(BeanL ...

  5. js中OOP小指南

    js中OOP小指南 在指南中,我将尝试解析以面向对象规范聚焦的es6的新特性. 首先, 什么是设计模式 范例是某个事务的例子或模型,在某种情况下,按照一种模式创建了计算机程序. 什么是面向对象 显然你 ...

  6. (转载)grep的使用

    R的意思是递归的对目录下的所有文件(包括子目录)进行 grep. 比如 grep -R main src就会搜索src目录下所有文件中是否包含 main 这个字符串. 因此grep -R " ...

  7. NOIP2014飞扬的小鸟

    长为n,高为m的二维平面,其中有k个管道(忽略管道的宽度)小鸟始终在游戏界面内移动.从最左边任意高度位置出发,到达游戏界面最右边,游戏完成每个单位时间沿横坐标方向右移距离为1,竖直移动的距离由玩家控制 ...

  8. 学习LSM(Linux security module)之四:一个基于LSM的简单沙箱的设计与实现

    嗯!如题,一个简单的基于LSM的沙箱设计.环境是Linux v4.4.28.一个比较新的版本,所以在实现过程中很难找到资料,而且还有各种坑逼,所以大部分的时间都是在看源码,虽然写的很烂,但是感觉收获还 ...

  9. [xsy1294]sub

    给出一棵$N$个节点的无根树,节点$i$有权值$v_i$.现在有$M$次操作,操作有如下两种: $1\ x\ y$ 将节点$x$的权值$v_x$修改为$y$ $2$ 选择一个联通块(也可以不选择),使 ...

  10. 【基数排序】Divide by Zero 2017 and Codeforces Round #399 (Div. 1 + Div. 2, combined) C. Jon Snow and his Favourite Number

    发现值域很小,而且怎么异或都不会超过1023……然后可以使用类似基数排序的思想,每次扫一遍就行了. 复杂度O(k*1024). #include<cstdio> #include<c ...