c# - How to run LINQ 'let' statements in parallel? -
मेरे पास ऐसा कोड है:
var list = new list & lt; int & gt; {1, 2, 3, 4, 5}; Var परिणाम = एक्स में सूची में। एस्पेरेलल () एक = लंगरिंगकैल्को 1 (एक्स) दें बी = लंगरिंगकैल्को 2 (एक्स) नया {a, b} चुनें;
हम कहते हैं कि लोंगरलिंगकैकल
तरीके प्रत्येक को 1 सेकंड लेते हैं। ऊपर दिए गए कोड को चलाने के लिए लगभग 2 सेकंड लगते हैं, क्योंकि 5 तत्वों की सूची समानांतर पर संचालित होती है, क्योंकि चलो
स्टेटमेंट से बुलाए गए दो तरीकों को क्रमिक रूप से कहा जाता है।
हालांकि , इन विधियों को सुरक्षित रूप से समानांतर में भी बुलाया जा सकता है। उन्हें स्पष्ट रूप से चुनें
के लिए मर्ज करने की आवश्यकता है, लेकिन तब तक समानांतर में चलना चाहिए - चुनें
उनके लिए इंतजार करना चाहिए।
क्या कोई तरीका है
आप क्वेरी सिंटैक्स या यह आपको लिखने की अनुमति देगा: आप अतिरिक्त समांतर संचालन के लिए ओवरलोड भी जोड़ सकते हैं: संकलित समय में कई चयनकर्ताओं को संभाल करने के लिए एक संस्करण लिखना संभव है, लेकिन ऐसा करने के लिए उन सभी को एक ही प्रकार के मान की गणना करने की आवश्यकता है: का उपयोग करने में सक्षम नहीं होंगे ऑपरेशन, लेकिन आप समानांतर में प्रत्येक आइटम के लिए कई कार्रवाइयां करने के लिए एक विधि लिख सकते हैं:
सार्वजनिक स्थिर समानांतरता & lt; TFinal & gt; चयन करेंसभी & lt; टी, TResult1, TResult2, TFinal & gt; (यह ParallelQuery & lt; T & gt; क्वेरी, फ़ंक्शन & lt; T, TResult1 & gt; चयनकर्ता 1, फ़नक & lt; T, TRsult2 & gt; चयनकर्ता 2, फ़ंक्स & lt; TResult1, TResult2, TFinal & gt; परिणामअगेटर) {वापसी क्वेरी। आइटम = & gt; {var result1 = कार्य.रुण (() = & gt; चयनकर्ता 1 (वस्तु)); var परिणाम 2 = कार्य.रुण (() = & gt; चयनकर्ता 2 (आइटम)); परिणामस्वरूप परिणामस्वरूपअगेटर (परिणाम 1। परिणाम, परिणाम 2 परिणाम); }); }
var query = list.AsParallel ()। चयन करेंल (LongRunningCalc1, LongRunningCalc2, (a, b) = & Gt; नया {a, b})
सार्वजनिक स्थिर समानांतरता & lt; टीफ़नल & gt; चुनें सभी & lt; टी, TResult1, TResult2, TResult3, TFinal & gt; (यह पैरालेलक्वेरी & lt; T & gt; क्वेरी, फ़ंक्शन & lt; T, TResult1 & gt; चयनकर्ता 1, फ़ंक्स & lt; टी, ट्रसल्ट 2 & gt; चयनकर्ता 2, फ़ंक् & टीटी; टी, ट्रस्ट 3 & gt; चयनकर्ता 3, फ़ंक्स & lt; ट्रस्ट 1, ट्रसल्ट 2, ट्रेशल 3, टीएफनल & gt; परिणाम एगेजेटर) {वापसी क्वेरी। आइटम = & gt; {var परिणाम 1 = कार्य.रुण (() = & gt; चयनकर्ता 1 (वस्तु)); var परिणाम 2 = कार्य.रुण (() = & gt; चयनकर्ता 2 (वस्तु)); var परिणाम 3 = कार्य.रुन (() = & Gt; चयनकर्ता 3 (आइटम)); वापसी परिणामअग्रेगेटर (परिणाम 1। परिणाम, परिणाम 2। परिणाम, परिणाम 3। परिणाम);}); }
सार्वजनिक स्थिर पैरालेलक्वेरी & lt; IEnumerable & lt; TRTTULT & gt; & gt; चयन करेंसभी & lt; T, TResult & gt; (यह ParallelQuery & lt; T & gt; क्वेरी, IEnumerable & lt; Func & lt; T, TResult & gt; & gt; चयनकर्ता) {वापसी क्वेरी। चयन करें (आइटम = & gt; चयनकर्ता। एस्पेरेल ()। चयन करें (चयनकर्ता = & gt; चयनकर्ता आइटम))। एएनएनमेरेबल ()); } पब्लिक स्टेटिक पैरालेलक्वेरी & lt; IEnumerable & lt; TRTTULT & gt; & gt; चुनें सभी & lt; T, TResult & gt; (यह ParallelQuery & lt; T & gt; क्वेरी, पैरामीटर फ़ंक्शन & lt; T, TResult & gt; [] चयनकर्ता) {Select Select All (क्वेरी, चयनकर्ता); }
Comments
Post a Comment