欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Parallel.ForEach怎么在C#項目中使用

Parallel.ForEach怎么在C#項目中使用?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

網(wǎng)站建設(shè)公司,為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計及定制網(wǎng)站建設(shè)服務,專注于企業(yè)網(wǎng)站建設(shè),高端網(wǎng)頁制作,對成都工商代辦等多個行業(yè)擁有豐富的網(wǎng)站建設(shè)經(jīng)驗的網(wǎng)站建設(shè)公司。專業(yè)網(wǎng)站設(shè)計,網(wǎng)站優(yōu)化推廣哪家好,專業(yè)成都網(wǎng)站營銷優(yōu)化,H5建站,響應式網(wǎng)站。

int num = 1;
      List<int> list = new List<int>();
      for (int i = 1; i <= 2000; i++)
      {
        list.Add(i);
      }
      Console.WriteLine($"num初始值為:" + num.ToString());
      list.AsParallel().ForAll(n =>
      {
        num++;
      });
      Console.WriteLine($"不加鎖,并發(fā){list.Count}次后為:" + num.ToString());
      Console.ReadKey();

這段代碼是讓一個變量執(zhí)行2000次自增,正常結(jié)果應該是2001,但實際結(jié)果如下:

Parallel.ForEach怎么在C#項目中使用

有經(jīng)驗的同學,立馬能想到需要加鎖了,C#內(nèi)置了很多鎖對象,如lock 互斥鎖,Interlocked 內(nèi)部鎖,Monitor 這幾個比較常見,lock內(nèi)部實現(xiàn)其實就是使用了Monitor對象。對變量自增,Interlocked對象提供了,變量自增,自減、或者相加等方法,我們使用自增方法Interlocked.Increment,函數(shù)定義為:int Increment(ref int num),該對象提供原子性的變量自增操作,傳入目標數(shù)值,返回或者ref num都是自增后的結(jié)果。 在之前的基礎(chǔ)上我們增加一些代碼:

num = 1;
      Console.WriteLine($"num初始值為:" + num.ToString());
      list.AsParallel().ForAll(n =>
      {
        Interlocked.Increment(ref num);
      });
      Console.WriteLine($"使用內(nèi)部鎖,并發(fā){list.Count}次后為:" + num.ToString());
      Console.ReadKey();

我們來看運行結(jié)果:

Parallel.ForEach怎么在C#項目中使用

加了鎖之后ID重復算是解決了,其實別高興太早,由于正常的環(huán)境有了ID我們還有用這些ID來構(gòu)建對象呢,于是又寫了寫代碼,用集合來添加這些ID,為了更真實的模擬生產(chǎn)環(huán)境,我在forAll里面又加了一層循環(huán)代碼如下:

num = 1;
      Random random = new Random();
      var total = 0;
      var m = new ConcurrentBag<int>();
      list.AsParallel().ForAll(n =>
      {
        var c = random.Next(1, 50);
        Interlocked.Add(ref total, c);
        for (int i = 0; i < c; i++)
        {
          Interlocked.Increment(ref num);
          m.Add(num);
        }
      });
      Console.WriteLine($"使用內(nèi)部鎖,并發(fā)+內(nèi)部循環(huán){list.Count}次后為:" + num.ToString());
      Console.WriteLine($"實際值為:{total + 1}");
      var l = m.GroupBy(n => n).Where(o => o.Count() > 1);
      Console.WriteLine($"并發(fā)里面使用安全集合ConcurrentBag添加num,集合重復值:{l.Count()}個");
      Console.ReadKey();

Parallel.ForEach怎么在C#項目中使用

上面的代碼里面我用到了線程安全集合ConcurrentBag<T>它的命名空間是:using System.Collections.Concurrent,盡管使用了線程安全集合,但是在并發(fā)面前仍然是不安全的,到了這里其實比較郁悶了,自增加鎖,安全集合內(nèi)部應該也使用了鎖,但還是重復了。有點說不過去了,想想多線程執(zhí)行時有個上下文對象,即當多個線程同時執(zhí)行任務,共享了變量他們一開始傳進去的對象數(shù)值應該是相同的,由于變量自增時加了鎖,所以ID是不會重復了。我猜測問題應該出在Add方法了,就是說當num值自增后還沒有來得及傳出去就已經(jīng)執(zhí)行了Add方法,故添加了重復變量。于是乎,我重新寫了段代碼,讓ID自增和集合添加都放到鎖里面:

num = 1;
      total = 0;
      using (var q = new BlockingCollection<int>())
      {
        list.AsParallel().ForAll(n =>
        {
          var c = random.Next(1, 50);
          Interlocked.Add(ref total, c);
          for (int i = 0; i < c; i++)
          {
            
            // Task.Delay(100);
            q.Add(Interlocked.Increment(ref num));
            
            //可控
            //lock (objLock)
            //{
            //  num++;
            //  q.Add(num);
            //}
          }

        });
        q.CompleteAdding();
        Console.WriteLine($"num累計值為:{total},并發(fā)之后值為:{num}");
        var x = q.GroupBy(n => n).Where(o => o.Count() > 1);
        Console.WriteLine($"并發(fā)使用安全集合BlockingCollection+Interlocked添加num,集合重復值:{x.Count()}個");
        Console.ReadKey();
      }

這里我測試了另外一個線程安全的集合BlockingCollection,關(guān)于這個集合的使用請自行查找MSDN文檔,上面的關(guān)鍵代碼直接添加安全集合的返回值,可以保證集合不會重復,但其實下面的lock更適用與正式環(huán)境,因為我們添加的一般都是對象不會是基礎(chǔ)類型數(shù)值,運行結(jié)果如下:

Parallel.ForEach怎么在C#項目中使用

至此,我們的問題解決了,計算時間由原來的9分多降至110秒左右,可見Parallel的處理還是很給力的,唯一不足的是,很占CPU,執(zhí)行計算后CPU達到了88%。附上計算結(jié)果:

Parallel.ForEach怎么在C#項目中使用

優(yōu)化前后對比

Parallel.ForEach怎么在C#項目中使用

關(guān)于Parallel.ForEach怎么在C#項目中使用問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。

網(wǎng)站題目:Parallel.ForEach怎么在C#項目中使用
URL網(wǎng)址:http://aaarwkj.com/article40/ihpceo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化、品牌網(wǎng)站建設(shè)網(wǎng)站制作、網(wǎng)站營銷、外貿(mào)網(wǎng)站建設(shè)、小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
亚洲女同在线免费观看| 国产尹人99大香蕉| 91欧美一区二区在线视频| 亚洲av天堂在线观看| 日本啪啪精品一区二区三区| 久久国产精品久久国产精品| 久久久久久成人亚洲| 国产一区二区爽爽爽视频| 国产福利精品一区二区av | 麻豆片免费观看在线看| 成年人免费观看黄色片| 岛国大片日韩在线观看| 激情五月,开心五月深情五月| 无套内谢少妇高朝毛片| 亚洲中文字幕婷婷在线| 国产三级久久精品三级91| 亚洲理论在线观看电影| 欧美精品国产欧美精品国产| 欧美日韩福利一区二区三区| 白浆熟女精品国产91| 香蕉视频欧美日韩国产| 中文字幕日本人妻乱码| 亚洲国产理论片在线观看| 国产黄片a三级久久久久久| 亚洲熟妇中文字幕五十中出| 亚洲天堂岛av一区二区| 中文字幕国产精品综合一区| 搡老女人老91妇女老熟女| 欧美久久精品在线观看| 一区二区三区欧美日| 97水蜜桃视频在线观看| 69精品一区二区蜜桃视频| 日韩精品成人区中文字幕| 女人天堂网av免费看| 青青草免费在线视频蜜臀| 久久最新视频中文字幕| 亚洲午夜精品日韩乱码| 色婷婷av一区二区三| 熟女aaa一区二区午夜| 日韩欧美国产精品一区二区三区 | 亚洲精品区免费观看av|