LINQ查詢基于泛型類型淺析
Linq有很多值得學(xué)習(xí)的地方,這里我們主要介紹LINQ查詢基于泛型類型,包括介紹LINQ 查詢中的 IEnumerable 變量等方面。
LINQ查詢基于泛型類型,在 .NET Framework 的 2.0 版中引入了泛型類型。您無需深入了解泛型即可開始編寫查詢。但是,您可能需要了解兩個(gè)基本概念:
◆當(dāng)您創(chuàng)建泛型集合類(如 List<(Of <(T>)>))的實(shí)例時(shí),您將“T”替換為列表將包含的對(duì)象的類型。例如,字符串列表表示為 List,Customer 對(duì)象列表表示為 List。泛型列表是強(qiáng)類型的,且提供了比將其元素存儲(chǔ)為 Object 的集合更多的好處。如果您嘗試將 Customer 添加到 List,則會(huì)在編譯時(shí)出現(xiàn)一條錯(cuò)誤。泛型集合易于使用的原因是您不必執(zhí)行運(yùn)行時(shí)類型強(qiáng)制轉(zhuǎn)換。
◆IEnumerable<(Of <(T>)>) 是一個(gè)接口,通過該接口,可以使用 foreach 語句來枚舉泛型集合類。泛型集合類支持 IEnumerable<(Of <(T>)>),就像非泛型集合類(如 ArrayList)支持 IEnumerable。
LINQ 查詢中的 IEnumerable 變量
LINQ 查詢變量類型化為 IEnumerable<(Of <(T>)>) 或派生類型,如 IQueryable<(Of <(T>)>)。當(dāng)您看到類型化為 IEnumerable 的查詢變量時(shí),這只意味著在執(zhí)行該查詢時(shí),該查詢將生成包含零個(gè)或多個(gè) Customer 對(duì)象的序列。
- 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ù)源來推斷查詢變量的類型。下面的示例生成與上一個(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í)到這可能使您的代碼更難以讓別人理解。以上介紹LINQ查詢基于泛型類型
【編輯推薦】