LINQ查詢和泛型類型的關(guān)系淺析
LINQ查詢和泛型類型的關(guān)系是什么呢?LINQ查詢和泛型類型內(nèi)在的聯(lián)系是如何的呢?我們在實際的操作過程中如何把握呢?那么這里就向你簡單介紹一下。
LINQ查詢基于泛型類型,在 .NET Framework 的 2.0 版中引入了泛型類型。您無需深入了解泛型即可開始編寫查詢。但是,您可能需要了解兩個基本概念:
1.當(dāng)您創(chuàng)建泛型集合類(如 List﹤(Of ﹤(T﹥)﹥))的實例時,您將“T”替換為列表將包含的對象的類型。例如,字符串列表表示為 List﹤string﹥,Customer 對象列表表示為 List﹤Customer﹥。泛型列表是強類型的,且提供了比將其元素存儲為 Object 的集合更多的好處。如果您嘗試將 Customer 添加到 List﹤string﹥,則會在編譯時出現(xiàn)一條錯誤。泛型集合易于使用的原因是您不必執(zhí)行運行時類型強制轉(zhuǎn)換。
2.IEnumerable﹤(Of ﹤(T﹥)﹥) 是一個接口,通過該接口,可以使用 foreach 語句來枚舉泛型集合類。泛型集合類支持 IEnumerable﹤(Of ﹤(T﹥)﹥),就像非泛型集合類(如 ArrayList)支持 IEnumerable。
3.LINQ 查詢變量類型化為 IEnumerable﹤(Of ﹤(T﹥)﹥) 或派生類型,如 IQueryable﹤(Of ﹤(T﹥)﹥)。當(dāng)您看到類型化為 IEnumerable﹤Customer﹥ 的查詢變量時,這只意味著在執(zhí)行該查詢時,該查詢將生成包含零個或多個 Customer 對象的序列。
LINQ查詢的使用:
- IEnumerable﹤Customer﹥ customerQuery =
- from cust in customers
- where cust.City == "London"
- select cust;
- foreach (Customer customer in customerQuery)
- {
- Console.WriteLine(customer.LastName +
- ", " + customer.FirstName);
- }
如果您愿意,可以使用 var 關(guān)鍵字來避免使用泛型語法。var 關(guān)鍵字指示編譯器通過查看在 from 子句中指定的數(shù)據(jù)源來推斷查詢變量的類型。下面的示例生成與上一個示例相同的編譯代碼:
- var customerQuery2 =
- from cust in customers
- where cust.City == "London"
- select cust;
- foreach(var customer in customerQuery2)
- {
- Console.WriteLine(customer.LastName +
- ", " + customer.FirstName);
- }
當(dāng)變量的類型明顯或顯式指定嵌套泛型類型(如由組查詢生成的那些類型)并不重要時,var 關(guān)鍵字很有用。通常,我建議如果您使用 var,應(yīng)意識到這可能使您的代碼更難以讓別人理解。
若要有效編寫查詢,您應(yīng)該了解完整的查詢操作中的變量類型是如何全部彼此關(guān)聯(lián)的。如果您了解這些關(guān)系,就能夠更容易地理解文檔中的 LINQ 示例和代碼示例。另外,還能了解在使用 var 隱式對變量進(jìn)行類型化時的后臺操作。
LINQ 查詢操作在數(shù)據(jù)源、查詢本身及查詢執(zhí)行中是強類型的。查詢中變量的類型必須與數(shù)據(jù)源中元素的類型和 foreach 語句中迭代變量的類型兼容。此強類型保證在編譯時捕獲類型錯誤,以便可以在用戶遇到這些錯誤之前更正它們。
為了演示這些類型關(guān)系,下面的大多數(shù)示例對所有變量使用顯式類型。
LINQ查詢的一些問題:
下圖演示不對數(shù)據(jù)執(zhí)行轉(zhuǎn)換的 LINQ to Objects 查詢操作。源包含一個字符串序列,查詢輸出也是一個字符串序列。
1.數(shù)據(jù)源的類型參數(shù)決定范圍變量的類型。
2.選擇的對象的類型決定查詢變量的類型。此處的 name 為一個字符串。因此,查詢變量是一個 IEnumerable﹤string﹥。
3.在 foreach 語句中循環(huán)訪問查詢變量。因為查詢變量是一個字符串序列,所以迭代變量也是一個字符串。
下圖演示對數(shù)據(jù)執(zhí)行簡單轉(zhuǎn)換的 LINQ to SQL 查詢操作。查詢將一個 Customer 對象序列用作輸入,并只選擇結(jié)果中的 Name 屬性。因為 Name 是一個字符串,所以查詢生成一個字符串序列作為輸出。
1.數(shù)據(jù)源的類型參數(shù)決定范圍變量的類型。
2.select 語句返回 Name 屬性,而非完整的 Customer 對象。因為 Name 是一個字符串,所以 custNameQuery 的類型參數(shù)是 string,而非 Customer。
3.因為 custNameQuery 是一個字符串序列,所以 foreach 循環(huán)的迭代變量也必須是 string。
下圖演示稍微復(fù)雜的轉(zhuǎn)換。select 語句返回只捕獲原始 Customer 對象的兩個成員的匿名類型。
1.數(shù)據(jù)源的類型參數(shù)始終為查詢中的范圍變量的類型。
2.因為 select 語句生成匿名類型,所以必須使用 var 隱式類型化查詢變量。
3.因為查詢變量的類型是隱式的,所以 foreach 循環(huán)中的迭代變量也必須是隱式的。
4.雖然您應(yīng)該了解查詢操作中的類型關(guān)系,但是您也可以選擇讓編譯器為您執(zhí)行全部工作。關(guān)鍵字 var 可用于查詢操作中的任何局部變量。下圖與前面討論的第二個示例完全等效。***的區(qū)別是編譯器將為查詢操作中的各個變量提供強類型:
LINQ查詢以及LINQ查詢和泛型類型的關(guān)系的基本內(nèi)容就向你介紹到這里,希望對你了解和掌握LINQ查詢和泛型類型的關(guān)系有所幫助。
【編輯推薦】