[翻译]“LINQ to Objects”提供程序是否内置性能优化?
原文來自Alexandra Rusina在CSharpFAQ的:Does the “LINQ to Objects” provider have built-in performance optimization?
?
讓我們從基礎(chǔ)開始,可能會重復(fù)一些你已經(jīng)知道的信息。在LINQ性能優(yōu)化中最重要的一點,當然是延遲執(zhí)行。那便意味著當你聲明一個變量并分配給它一個查詢字符串,其查詢字符串并沒有立即執(zhí)行。
?
//?查詢沒有執(zhí)行。
var?query =?from?item?in?storage?select?item;
??
變量query現(xiàn)在存儲著命令,查詢執(zhí)行被延遲直到你從變量query請求獲取數(shù)據(jù)。這通常發(fā)生在如下幾種情況:foreach循環(huán),或當你調(diào)用一個聚集函數(shù)像Min,Max和Average,或當你使用ToList或ToArray方法緩存該查詢結(jié)果。
?
// foreach循環(huán)。
foreach?(var?item?in?query)
????Console.WriteLine(item);
?
// Count函數(shù)。
int?total = query.Count();
?
// ToArray方法。
var?cachedQuery = query.ToArray();
?
現(xiàn)在讓我們來看看幕后究竟發(fā)生了什么。在查詢執(zhí)行的時候是否有什么編譯器級的優(yōu)化發(fā)生?答案是yes。然而,這里有個陷阱。從現(xiàn)在起我們將只討論使用“LINQ to Objects”提供程序?qū)?/span>IEnumerable和IEnumerable<T>集合的查詢。對于其他LINQ提供程序,包括LINQ to SQL和LINQ to XML,可能應(yīng)用的是不同的優(yōu)化規(guī)則。
?
注意:人們常常認為,由于延遲執(zhí)行,執(zhí)行第一次查詢需要花費更長時間。然而,在LINQ to Objects中,第一次執(zhí)行和之后的每一次并沒有差別。其他LINQ提供程序的規(guī)則可能不同(比如,這里可能有些會進行緩存),但你需要參考特定的提供程序的詳細文檔。
?
?LINQ to Objects查詢在下面這些情況下會做優(yōu)化:
?
- 一些方法調(diào)用會被優(yōu)化,如果數(shù)據(jù)源實現(xiàn)了一個必要的接口。下面表格列出了這些優(yōu)化。
??
| LINQ方法 | 優(yōu)化 |
| Cast | 如果數(shù)據(jù)源已經(jīng)對給定的類型T實現(xiàn)接口IEnumerable<T>,則會直接返回數(shù)據(jù)序列而不需要轉(zhuǎn)換。 |
| Contains | 如果數(shù)據(jù)源實現(xiàn)了接口ICollection或ICollection<T>,其接口的相應(yīng)的方法會被使用。 |
| Count | |
| ElementAt | 如果數(shù)據(jù)源實現(xiàn)了接口IList或IList<T>,接口的Count方法和索引器會被使用。 |
| ElementAtOrDefault | |
| First | |
| FirstOrDefault | |
| Last | |
| LastOrDefault | |
| Single | |
| SingleOrDefault |
?
??
- 如果連續(xù)的一個或多個Select操作后面跟著連續(xù)的一個或多個Where操作,查詢只會創(chuàng)建一個IEnumerable或IEnumerable<T>對象而不會創(chuàng)建中間對象。
?
var?query =?from?item?in?storage
????????????where?item.Category =?"Food"
????????????where?item.Price < 100
????????????select?item;
?
在這里,查詢只會創(chuàng)建一個IEnumerable對象。??
- 如果你查詢一個數(shù)組或List,接口IEnumerable或IEnumerable<T>不會在foreach循環(huán)中使用枚舉器。相反,在使用前會創(chuàng)建一個數(shù)組或List的簡單for循環(huán),元素被直接訪問。
?
此外,where操作符實現(xiàn)了簡單的if語句,所以不會有中間的枚舉器產(chǎn)生。
?
再次說明,其他LINQ提供程序可能擁有它們自己的性能優(yōu)化規(guī)則。但上面的規(guī)則應(yīng)該能給你一些怎么使用LINQ to Objects的意見。
轉(zhuǎn)載于:https://www.cnblogs.com/tianfan/archive/2010/03/03/does-the-linq-to-objects-provider-have-built-in-performance-optimization.html
總結(jié)
以上是生活随笔為你收集整理的[翻译]“LINQ to Objects”提供程序是否内置性能优化?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 灼灼夏日 - 遥思故乡 - 赤子无相忘
- 下一篇: 增加RSS订阅量的35个方法