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