Parallel類如何c#中使用-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)Parallel類如何c# 中使用,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

十年專注成都網(wǎng)站制作,成都企業(yè)網(wǎng)站定制,個人網(wǎng)站制作服務(wù),為大家分享網(wǎng)站制作知識、方案,網(wǎng)站設(shè)計(jì)流程、步驟,成功服務(wù)上千家企業(yè)。為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計(jì)及定制高端網(wǎng)站建設(shè)服務(wù),專注于成都企業(yè)網(wǎng)站定制,高端網(wǎng)頁制作,對成都活動板房等多個領(lǐng)域,擁有多年建站經(jīng)驗(yàn)。

Parallel類是對線程的抽象,提供數(shù)據(jù)與任務(wù)的并行性。類定義了靜態(tài)方法For和ForEach,使用多個任務(wù)來完成多個作業(yè)。Parallel.For和Parallel.ForEach方法在每次迭代的時候調(diào)用相同的代碼,而Parallel.Invoke()方法允許同時調(diào)用不同的方法。Parallel.ForEach()方法用于數(shù)據(jù)的并行性,Parallel.Invoke()方法用于任務(wù)的并行性。

1、For()方法

For()方法用于多次執(zhí)行一個任務(wù),可以并行運(yùn)行迭代,但迭代的順序并沒指定。For()方法前兩個參數(shù)為定義循環(huán)的開始和結(jié)束,第三個參數(shù)為Action<int>委托。方法的返回值是ParallelLoopResult結(jié)構(gòu),它提供了是否結(jié)束的信息。如以下循環(huán)方法,不能保證輸出順序:

static void ParallelFor()
{
  ParallelLoopResult result =
    Parallel.For(0, 10, async i =>
      {
        Console.WriteLine("{0}, task: {1}, thread: {2}", i,
          Task.CurrentId, Thread.CurrentThread.ManagedThreadId);

        await Task.Delay(10);//異步方法,用于釋放線程供其他任務(wù)使用。完成后,可能看不到方法的輸出,因?yàn)橹?前臺線)程結(jié)束,所有的后臺線程也將結(jié)束
        Console.WriteLine("{0}, task: {1}, thread: {2}", i, Task.CurrentId, Thread.CurrentThread.ManagedThreadId);
      });
  Console.WriteLine("Is completed: {0}", result.IsCompleted);
}

文章標(biāo)題:Parallel類如何c#中使用-創(chuàng)新互聯(lián)
網(wǎng)站路徑:http://muchs.cn/article32/eicsc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站網(wǎng)站設(shè)計(jì)公司、網(wǎng)頁設(shè)計(jì)公司、動態(tài)網(wǎng)站、微信小程序、定制網(wǎng)站

廣告

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

h5響應(yīng)式網(wǎng)站建設(shè)