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

C# 中奇妙的函數 -- 1. ToLookup

編輯:C#入門知識

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

好的!先來看看ToLookup:

下文參考翻譯自:

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

故事的背景

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

     public sealed class Product
    {
        public int Id { get; set; }
        public string Category { get; set; }
        public double Value { get; set; }
        

        public override string ToString()
        {
            return string.Format("[{0}: {1} - {2}]", Id, Category, Value);
        }
    }

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

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


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

             foreach (var group in products.GroupBy(p => p.Category))
            {
                Console.WriteLine(group.Key);
                foreach (var item in group)
                {
                    Console.WriteLine("	" + item);
                }
            }


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

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

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

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

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