Linq'ten önce, bir koleksiyonun boş olup olmadığını belirlemek için genellikle aşağıdaki yöntemi kullanırdık, yani bir koleksiyon elemanlar içerir:
Uzunluk veya Sayı özelliğini kullandığınızda, yukarıdaki yazımda bir sorun yoktur.
Ancak Linq döneminde, Enumerable.Count uzatma yöntemi Length ve Count özelliklerini "birleştirerek" geçersiz olmamayı değerlendirmek için aşağıdaki yazım yöntemini ortaya çıkardı:
Bu yazı gayet iyi ve iyi çalışıyor, ama çok ciddi performans sorunlarına yol açabilir.
Bunun mümkün olduğunu, ancak mutlaka olmadığını unutmayın ve yukarıdaki yöntem Dizi<T>, Liste veya Koleksiyon olarak <T>aktarılırsa sorun olmaz.
Peki ne zaman bir şeyler ters gidecek? Aşağıdaki yöntemlere bakalım:
Çağrındığında:
Uygulama hızı oldukça yavaş olacak ve bilgisayarımın kaynağı çalıştırması yaklaşık 70 saniye sürdü. Count() > 0。
Analiz ederseniz, GetNums kodunun 5. satırındaki yield return'un int çalıştırıldığını göreceksiniz. MaxValue, gerekli mi?
Aslında, bir eleman döndürdüğümüz sürece, kümenin boş olmadığı sonucuna varabiliriz ve tüm elemanları geri göndermeye gerek yoktur.
Peki nasıl yargılanacak? Enumerable.Herhangi bir uzantı yöntemini kullanabiliriz:
SomeAction yöntemini aşağıdaki şekilde değiştirin:
Tekrar karar ver, infaz süresinin önemsiz olduğunu göreceksiniz.
Özetle, Count() > 0 dönüşle karşılaştığında kaçınılmaz olarak performans sorunları yaşayacaktır.
|