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

  • Google Россия

    Google Ро

    9 Temmuz 2007
  • hanksranger

    hanksranger

    6 EKİM 2009
  • warningthepeople

    warningthepe

    21 EYLÜL 2011