亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

并行編程中的取消任務、共享狀態,等等

2019-11-14 14:11:16
字體:
來源:轉載
供稿:網友

 

在面對相互獨立的數據或者相互獨立的任務時,也許正是Parallel登場的時候。

 

比如說有一個盒子的集合,分別讓盒子旋轉一定的角度。

 

void RotateBox(IEnumerable<Box> boxes, float degree)
{
    Parallel.ForEach(boxes, box => box.Rotate(degree));
}

 

如果并行任務中的一個任務出現異常,需要結束出問題的任務呢?

 

Parallel.ForEach為我們提供了一個重載方法,可以控制任務是否繼續。

 

void RotateBoxes(IEnumerable<Box> boxes)
{
    Parallel.ForEach(boxes, (box, state) => {
        if(!box.IsInvertible)
        {
            state.Stop();
        }
        else
        {
            box.Invert();
        }
    });
}

 

如果想取消整個并行任務呢?

 

Parallel.ForEach也為我們提供一個重載方法,可以接收一個ParallelOption的形參,通過設置ParallelOption的CancellationToken屬性來取消整個并行過程。

 

void RotateBoxes(IEnumerable<Box> boxes,float degrees, CancellationToken token)
{
    Paralle.ForEach(boxes, 
    new ParallelOptions{CancellationToken=token},
    box => box.Rotate(degrees));
}

 

在使用的時候,一般先定義個全局CancellationTokenSource類型的變量。

 

static CancellationTokenSource token = new CancellationTokenSource();

 

然后,在某個并行任務中設置取消。

 

token.Cancel();

 

最后,再把這個token賦值給以上方法的CancellationToken屬性。

 

各個并行任務如何共享狀態,共享一個變量呢?

 

int InvertBoxes(IEnumerable<Box> boxes)
{
    object mutex = new object();//用來鎖
    int nonInvertibleCount = 0; //各任務共享的變量
    Paralle.ForEach(boxes, box =>{
        if(box.IsInvertible){
            box.Invert();
        }
        else
        {
            lock(mutex)
            {
                ++nonInvertibleCount;
            }
        }
    });
    return nonInvertibleCount;
}

 

可見,對于各并行線程共享的變量,需要加一個線程鎖,以防止多個線程同時操作共享變量。

 

另外,Parallel.ForEach提供了一個重載,其中localFinally形參接收一個委托類型,通過該委托讓并行任務共享一個變量。比如:

 

static int ParallelSum(IEnumerable<int> values)
{
    object mutex = new object();
    int result = 0;
    Parallel.ForEach(
        source: values,
        LocalInit: () => 0,
        body: (item, state, localVlaue) => localValue + item,
        localFinally: localValue => {
            lock(mutex)
            {
                result += localValue;
            }
        }
    );
    return result;
}

 

當然,也別忘了PLINQ也支持并行

 

static int ParalleSum(IEnumerable<int> values)
{
    return values.asparallel().Sum();
}

 

PLINQ的Aggregate方法也可實現:

 

static int ParallelSum(IEnumerable<int> values)
{
    return values.AsParallel().Aggregate(
        seed: 0,
        func: (sum, item) => sum + item;
    );
}

 

以上,是對相互獨立數據的處理。

 

那么,如何處理相互獨立的多個任務呢?

 

通過Parallel.Invoke方法可以實現。

 

static voiD PRocessArray(double[] array)
{
    Parallel.Invoke(
        () => ProcessPartialArray(array, 0, array.Length/2),
        () => ProcessPartialArray(array, array.Length/2, array.Length)
    );
}
static void ProcessPartialArray(double[] array, int begin, int end)
{}

 

使用Parallel.Invoke方法還可以讓一個Action或這方法執行多次。

 

static void Do20(Action action)
{
    //讓某個Action執行20次
    Action[] actions = Enumerable.Repeat(action, 20).ToArray();
    Parallel.Invoke(actions);
}

 

Parallel.Invoke方法也提供了重載,接收ParallelOption類型的形參,用來控制取消整個并行過程。

 

static void Do20(Action action)
{
    //讓某個Action執行20次
    Action[] actions = Enumerable.Repeat(action, 20).ToArray();
    Parallel.Invoke(new ParallelOptions{CancellationToken = token},actions);
}

 

參考資料:C#并發編程經典實例


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩麻豆第一页| 欧美激情喷水视频| 91久久精品国产| 亚洲色图偷窥自拍| 国产精品视频在线观看| 国产啪精品视频网站| 日本午夜精品理论片a级appf发布| 国产精品美女主播在线观看纯欲| 欧美在线视频观看免费网站| 国产精品丝袜一区二区三区| 韩国三级日本三级少妇99| 成人黄色av免费在线观看| 欧美一级大片在线免费观看| 亚洲综合色激情五月| 欧美日韩免费在线| 国产成人在线一区| www.亚洲一区| 亚洲欧美激情视频| 精品无人区乱码1区2区3区在线| 欧美在线视频免费播放| 一本色道久久88综合日韩精品| 国产a∨精品一区二区三区不卡| 大桥未久av一区二区三区| 欧美在线性视频| 午夜精品福利在线观看| 亚洲18私人小影院| 92版电视剧仙鹤神针在线观看| 国内精品模特av私拍在线观看| 欧美性xxxxx极品娇小| 亚洲国产日韩欧美在线99| 国产99久久精品一区二区永久免费| 国产91精品久久久久久| 麻豆乱码国产一区二区三区| 日韩亚洲在线观看| 2018中文字幕一区二区三区| 日韩av有码在线| 中文字幕九色91在线| 国产精品电影在线观看| 日韩av在线精品| 国内免费久久久久久久久久久| 国产精品成人va在线观看| 国产成人精品电影久久久| 国产精品美女免费看| 久久激情视频免费观看| 国内精品久久久久久中文字幕| 国产精品免费久久久| 97精品欧美一区二区三区| 伊人一区二区三区久久精品| 在线视频精品一| 亚洲国产天堂久久国产91| 国产精品午夜一区二区欲梦| 成人网在线免费看| 亚洲最大的免费| 中文字幕精品在线视频| 亚洲精品www| 狠狠久久五月精品中文字幕| 久久久久久网站| 国产精品影院在线观看| 国产自产女人91一区在线观看| www欧美xxxx| 自拍偷拍亚洲精品| 欧美久久精品午夜青青大伊人| 91精品国产综合久久香蕉922| 久久久99免费视频| 91在线|亚洲| 日韩欧美精品网址| 国内偷自视频区视频综合| 国产精品欧美日韩一区二区| 欧美极品美女视频网站在线观看免费| 91av免费观看91av精品在线| 欧美大尺度在线观看| 久久av资源网站| 精品国产一区二区三区久久狼黑人| 国产欧美日韩中文字幕在线| 精品国偷自产在线视频99| 国产成人综合一区二区三区| 色综合视频一区中文字幕| 亚洲国产精品专区久久| 欧美激情videos| 91亚洲永久免费精品| 综合av色偷偷网| 最新中文字幕亚洲| 国产精品视频免费观看www| 国产欧美一区二区三区久久| 日韩av一区二区在线观看| 久久久久久久久久久国产| 色偷偷av亚洲男人的天堂| 91精品视频一区| 亚洲成人1234| 日韩一区二区久久久| 欧美日韩亚洲网| 日韩中文字幕在线免费观看| 欧美成人精品一区| 日本成人在线视频网址| 一本色道久久88综合日韩精品| 国产一区二区三区免费视频| 亚洲精品美女网站| 亚洲免费人成在线视频观看| 精品亚洲国产成av人片传媒| 尤物tv国产一区| 夜夜嗨av一区二区三区免费区| 欧美日韩亚洲国产一区| 最新国产精品拍自在线播放| 久久精品99久久香蕉国产色戒| 2021国产精品视频| 久久亚洲精品毛片| 国产精品久久电影观看| 97精品国产97久久久久久免费| 91久久在线观看| 国产精品福利在线观看网址| 国产精品美乳在线观看| 国产偷亚洲偷欧美偷精品| 66m—66摸成人免费视频| 亚洲激情视频在线| 国产欧美精品一区二区三区介绍| 综合网日日天干夜夜久久| 欧美精品激情blacked18| 国产精品免费一区豆花| 国产精品国产福利国产秒拍| 国产精品永久免费观看| 国产成人精品一区二区在线| 欧美天堂在线观看| 色偷偷噜噜噜亚洲男人的天堂| 青草青草久热精品视频在线网站| 国产福利视频一区二区| 亚洲精品福利视频| 久久久久久网站| 欧美重口另类videos人妖| 国产美女精品视频| 国产精品日韩在线| 亚洲天堂av图片| 国产精品成久久久久三级| 亚洲第一区中文字幕| 亚洲桃花岛网站| www日韩中文字幕在线看| 国产成人精品久久久| 九九热精品视频在线播放| 欧美国产日韩二区| 国产乱人伦真实精品视频| 琪琪亚洲精品午夜在线| 国产精品爽爽爽| 国产精品成人观看视频国产奇米| 91日本视频在线| 欧美日韩国产综合新一区| 黑人巨大精品欧美一区二区免费| 668精品在线视频| 日本最新高清不卡中文字幕| 亚洲精品自拍第一页| 国产精品视频自拍| 国产精品久久一区主播| 国产精品久久久久久久久久免费| 91色琪琪电影亚洲精品久久| 久久99久久99精品中文字幕| 色综合老司机第九色激情| 国产精品黄色av| 最近2019年日本中文免费字幕| 中文字幕欧美精品在线| 久久在线视频在线| 国产精品主播视频| 中国china体内裑精亚洲片| 国产精品视频午夜| 亚洲精品影视在线观看| 国内精品久久久久久影视8| 人人澡人人澡人人看欧美|