程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> 走進C#奇妙函數之ToLookup

走進C#奇妙函數之ToLookup

編輯:關於C語言

這個系列,我和大家一起來學學C#中一些非常有用函數,對於有些人來說可能它們不起眼,因此常常忽略它們。它們不會嚷嚷到:“使用我吧!我會讓你節省很多的時間,而且讓你的代碼變得更加的簡潔!” -- 但是,這些話會從對它們熟悉的程序員的腦海中湧現出來。

好的!先來看看ToLookup:

故事的背景

讓我們先來創建一個簡單的類來表示產品,產品有ID,類別,和價格,這個類沒有什麼特別:

  1. public sealed class Product  
  2.  
  3.    public int Id { get; set; }  
  4.    public string Category { get; set; }  
  5.    public double Value { get; set; }  
  6.     
  7.  
  8.    public override string ToString()  
  9.    {  
  10.        return string.Format("[{0}: {1} - {2}]", Id, Category, Value);  
  11.    }  

然後我們加入一個函數得到一個產品的列表,當然你也可以從數據庫中讀取出來:

  1. public static List<Product> GetList()  
  2.  {  
  3.      var products = new List<Product>  
  4.                         {  
  5.                             new Product {Id = 1, Category = "Electronics", Value = 15.0},  
  6.                             new Product {Id = 2, Category = "GrocerIEs", Value = 40.0},  
  7.                             new Product {Id = 3, Category = "Garden", Value = 210.3},  
  8.                             new Product {Id = 4, Category = "Pets", Value = 2.1},  
  9.                             new Product {Id = 5, Category = "Electronics", Value = 19.95},  
  10.                             new Product {Id = 6, Category = "Pets", Value = 21.25},  
  11.                             new Product {Id = 7, Category = "Pets", Value = 5.50},  
  12.                             new Product {Id = 8, Category = "Garden", Value = 13.0},  
  13.                             new Product {Id = 9, Category = "Automotive", Value = 10.0},  
  14.                             new Product {Id = 10, Category = "Electronics", Value = 250.0},  
  15.                         };  
  16.      return products;  
  17.  } 

我們有一個任務就是按類別列出一個物品清單,這個非常的容易,用GroupBy 就可以實現了:

  1. foreach (var group in products.GroupBy(p => p.Category))  
  2.  
  3.    Console.WriteLine(group.Key);  
  4.    foreach (var item in group)  
  5.    {  
  6.        Console.WriteLine("\t" + item);  
  7.    }  


看起來一切都很好,沒有什麼問題.

當我們使用 GroupBy() 擴展方法時,使用了延遲執行。 這意味著,當你遍歷集合的時候,下一個要出現的項目可能會或者可能不會被加載。 這是一個很大的性能改進,但它會引起有趣的副作用。

在用 GroupBy()時,  它實際上是在第一項被使用的時候創建分組,而不是在 GroupBy() 第一次被調用時。

考慮一下:如果你從數據庫中加載數據,然後想組合到一起,並存儲快速查找。  看下面的一段代碼:

  1.  var groups = products.GroupBy(p => p.Category);  
  2. //刪除所有屬於Garden的產品  
  3. products.RemoveAll(p => p.Category == "Garden");  
  4.  
  5. foreach (var group in groups)  
  6. {  
  7.     Console.WriteLine(group.Key);  
  8.     foreach (var item in group)  
  9.     {  
  10.         Console.WriteLine("\t" + item);  
  11.     }  

執行後發現,所有的Garden產品都已經消失了,但是 groups 是在執行刪除命令前就已經賦值了。

基於這種情況,我們不得不使用ToDictionary() 將GroupBy 後的結果儲存起來,這樣一來工作量就增加了,而且維護也不太方便 -- 請大家試試。

ToLookup登場

現在我們有請ToLookup。

該 ToLookup() 方法創建一個類似 字典(Dictionary ) 的列表List, 但是它是一個新的 .Net Collection 叫做 lookup。 Lookup,不像Dictionary, 是不可改變的。 這意味著一旦你創建一個lookup, 你不能添加或刪除元素。

  1.  var productsByCategory = products.ToLookup(p => p.Category);  
  2.  
  3.  foreach (var group in productsByCategory)  
  4. {  
  5.     // the key of the lookup is in key property  
  6.     Console.WriteLine(group.Key);  
  7.     // the list of values is the group itself.  
  8.     foreach (var item in group)  
  9.     {  
  10.         Console.WriteLine("\t" + item);  
  11.     }  

你還可以使用類似索引的功能得到某個項目,在本案例中是得到某個類別的所有產品:

  1.  private static void PrintCategory(ILookup<string, Product> productsByCategory,string categoryName)  
  2. {  
  3.     foreach (var item in productsByCategory[categoryName])  
  4.     {  
  5.         Console.WriteLine(item);  
  6.     }  


結論

ToLookup() 是一個奇妙的函數,用於對一個集合進行操作,創建一個1:n 的映射。 它可以方便的將數據分類成組,並生成一個字典供查詢使用。

原文鏈接:http://www.cnblogs.com/multiplesoftware/archive/2011/03/31/2000528.Html

【編輯推薦】

  1. C#取整函數實例應用詳解
  2. C#單元測試的一個小故事
  3. C#單元測試使用的必要性的淺析
  4. C#單元測試概念及作用的淺析
  5. C#單元測試的運行淺析

【責任編輯:彭凡 TEL:(010)68476606】

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved