Loading [MathJax]/extensions/tex2jax.js

2023年9月3日日曜日

C# Parallel 入門 2

やりたいこと
以前の記事がこちらになります。
C# Parallel 入門

前回の方法では、for文の中の計算結果を足し合わせるということをしていたのですが、
もう少し複雑なことがしたくなりました。

1からNまで順番に数字を調べていって、それが目当ての数字だったら、
Listに登録することが目的です。

コード
  1. // 並列化  
  2. object obj = new object();  
  3. Parallel.For<list<int64>>(1, endNum, () => new List<int64>(), (Int64 num, ParallelLoopState state, List<int64> partial) =>  
  4. {  
  5.     // もとめたい数字がきたらListに登録する  
  6.     if (num == XXX)  
  7.     {  
  8.         partial.Add(num);  
  9.     }  
  10.   
  11.     return partial;  
  12. },  
  13.     partial =>  
  14.     {  
  15.   
  16.         foreach (var val in partial)  
  17.         {  
  18.             lock (obj) motometeruList.Add(val);  
  19.         }  
  20.     });  
  21.   
  22. </int64></int64></list<int64>  
コードの説明
結果
for文でループさせる回数や中身の計算にもよると思いますが、
自分がやりたかった計算では、「40000000」までループさせる計算で、
Parallel使う前は1500秒だったものが、Parallelに変更すると、
300秒ぐらいで終わるようになりました。
0 件のコメント:
コメントを投稿