SORU
24 EYLÜL 2010, Cuma


Paralel.() ForEach(IEnumerable<T>.vs dosyalarda grup() AsParallel)

Erg, KORUYUCU olarak bu iki yöntem Reflektör kullanarak, ama onları bulamıyor bulmaya çalışıyorum. Bu iki parçacıkları arasındaki fark nedir?

Bir:

IEnumerable<string> items = ...

Parallel.ForEach(items, item => {
   ...
});

B:

IEnumerable<string> items = ...

foreach (var item in items.AsParallel())
{
   ...
}

Diğer üzerinde kullanarak farklı sonuçları vardır? (Her iki örnek parantez vücudunda ne yapıyorsam, iş parçacığı güvenli olduğu varsayılmaktadır.)

CEVAP
24 EYLÜL 2010, Cuma


Oldukça farklı bir şey yapıyorlar.

İlki anonim temsilci alır, ve tüm farklı öğeler için paralel olarak bu kod üzerinde birden çok iş parçacığı çalışır.

İkincisi, bu senaryoda yararlı. Özetle, birden çok iş parçacığı üzerinde sorgu yapmak ve sonuç birleştirmek için tasarlanmıştır, ve tekrar arama iş ver. Foreach deyimi kodu her zaman UI iş parçacığı üzerinde kalır.

Sadece eğer bir şey kontrol etmeniz AsParallel() çağrı sağında sorgu gibi pahalı yaparsan mantıklı:

 var fibonacciNumbers = numbers.AsParallel().Select(n => ComputeFibonacci(n));

Bunu Paylaş:
  • Google+
  • E-Posta
Etiketler:

YORUMLAR

SPONSOR VİDEO

Rastgele Yazarlar

  • Amir Parmar

    Amir Parmar

    25 Kasım 2010
  • Damian Winter

    Damian Winte

    27 ŞUBAT 2007
  • michal lelkowski

    michal lelko

    9 Temmuz 2006