zoukankan      html  css  js  c++  java
  • C# ToLookup

    下文参考翻译自:

    C#/.NET Little Wonders: The ToLookup() LINQ Extension Method

    故事的背景

    让我们先来创建一个简单的类来表示产品,产品有ID,类别,和价格,这个类没有什么特别:

     

    然后我们加入一个函数得到一个产品的列表,当然你也可以从数据库中读取出来:

     


    我们有一个任务就是按类别列出一个物品清单,这个非常的容易,用GroupBy 就可以实现了:

     


    看起来一切都很好,没有什么问题.

    当我们使用 GroupBy() 扩展方法时,使用了延迟执行。 这意味着,当你遍历集合的时候,下一个要出现的项目可能会或者可能不会被加载。 这是一个很大的性能改进,但它会引起有趣的副作用。

    在用 GroupBy()时,  它实际上是在第一项被使用的时候创建分组,而不是在 GroupBy() 第一次被调用时。

    考虑一下:如果你从数据库中加载数据,然后想组合到一起,并存储快速查找。  看下面的一段代码:

     


    执行后发现,所有的Garden产品都已经消失了,但是 groups 是在执行删除命令前就已经赋值了。

    基于这种情况,我们不得不使用ToDictionary() 将GroupBy 后的结果储存起来,这样一来工作量就增加了,而且维护也不太方便 -- 请大家试试。

    ToLookup登场

    现在我们有请ToLookup。

    ToLookup() 方法创建一个类似 字典(Dictionary ) 的列表List, 但是它是一个新的 .NET Collection 叫做 lookup。 Lookup,不像Dictionary, 是不可改变的。 这意味着一旦你创建一个lookup, 你不能添加或删除元素。

     

     

    你还可以使用类似索引的功能得到某个项目,在本案例中是得到某个类别的所有产品:

     

  • 相关阅读:
    Open Auth辅助库(使用ImitateLogin实现登录)
    dotNet使用HttpWebRequest模拟浏览器
    开源一个社交网站模拟登录的库
    Storm系列(三):创建Maven项目打包提交wordcount到Storm集群
    Storm系列(二):使用Csharp创建你的第一个Storm拓扑(wordcount)
    Storm系列(一):搭建dotNet开发Storm拓扑的环境
    单点登录原理与简单实现
    策略模式Strategy
    MySQL 主从复制
    Windows下搭建MySql Master-Master Replication
  • 原文地址:https://www.cnblogs.com/qixuejia/p/7284063.html
Copyright © 2011-2022 走看看