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

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

ParallelProgramming-多消費者,多生產者同時運行并行

2019-11-14 13:46:49
字體:
來源:轉載
供稿:網友

在上一篇文章演示了并行的流水線操作(生產者和消費者并行同時執行),C#是通過BlockingCollection這個線程安全的對象作為Buffer,并且結合Task來實現的。但是上一篇文章有個缺陷,在整個流水線上,生產者和消費者是唯一的。本文將演示多個消費者多個生產者同時并行執行。

一、多消費者、多生產者示意圖

 與前一篇文章演示的流水線思想類似,不同之處就是本文的topic:消費者和生產者有多個,以buffer1為例,起生產者有兩個,消費者有兩個,現在有三個緯度的并行:

  1. Action1和Action2并行(消費者和生產者并行)
  2. 消費者并行(Action2.1和Action2.2并行)
  3. 生產者并行(Action1.1和Action1.2并行)

二、實現

2.1 代碼

 class PiplelineDemo    {        PRivate int seed;        public PiplelineDemo()        {            seed = 10;        }        public void Action11(BlockingCollection<string> output)        {            for (var i = 0; i < seed; i++)            {                output.Add(i.ToString());//initialize data to buffer1            }        }        public void Action12(BlockingCollection<string> output)        {            for (var i = 0; i < seed; i++)            {                output.Add(i.ToString());//initialize data to buffer1            }        }        public void Action21(BlockingCollection<string> input, BlockingCollection<string> output)        {            foreach (var item in input.GetConsumingEnumerable())            {                var itemToInt = int.Parse(item);                output.Add((itemToInt * itemToInt).ToString());// add new data to buffer2            }        }        public void Action22(BlockingCollection<string> input, BlockingCollection<string> output)        {            foreach (var item in input.GetConsumingEnumerable())            {                var itemToInt = int.Parse(item);                output.Add((itemToInt * itemToInt).ToString());// add new data to buffer2            }        }        public void Action31(BlockingCollection<string> input, BlockingCollection<string> output)        {            foreach (var item in input.GetConsumingEnumerable())            {                output.Add((item));// add new data to buffer3            }        }        public void Action32(BlockingCollection<string> input, BlockingCollection<string> output)        {            foreach (var item in input.GetConsumingEnumerable())            {                output.Add((item));// add new data to buffer3            }        }        public void Pipeline()        {            var buffer1 = new BlockingCollection<string>(seed * 2);            var buffer2 = new BlockingCollection<string>(seed * 2);            var buffer3 = new BlockingCollection<string>(seed * 2);            var taskFactory = new TaskFactory(TaskCreationOptions.LongRunning, TaskContinuationOptions.None);            var stage11 = taskFactory.StartNew(() => Action11(buffer1));            var stage12 = taskFactory.StartNew(() => Action12(buffer1));            Task.Factory.ContinueWhenAll(new Task[] { stage11, stage12 }, (tasks) =>            {                buffer1.CompleteAdding();            });            var stage21 = taskFactory.StartNew(() => Action21(buffer1, buffer2));            var stage22 = taskFactory.StartNew(() => Action22(buffer1, buffer2));            Task.Factory.ContinueWhenAll(new Task[] { stage21, stage22 }, (tasks) =>            {                buffer2.CompleteAdding();            });            var stage31 = taskFactory.StartNew(() => Action31(buffer2, buffer3));            var stage32 = taskFactory.StartNew(() => Action32(buffer2, buffer3));            Task.Factory.ContinueWhenAll(new Task[] { stage31, stage32 }, (tasks) =>            {                buffer3.CompleteAdding();            });            Task.WaitAll(stage11, stage12, stage21, stage22, stage31, stage32);            foreach (var item in buffer3.GetConsumingEnumerable())//print data in buffer3            {                Console.WriteLine(item);            }        }    }

2.2 運行結果

2.3 代碼解釋

  1. Action11和Action12相對比較好理解。初始化數據到buffer1。
  2. Action2.1和Action2.2相對比較費解,他們同時接受buffer1作為輸入,為什么最終的結果Buffer2沒有產生重復? 最后由Action21,action22同時產生的buffer3為什么也沒有重復?這就是GetConsumingEnumerable這個方法的功勞。這個方法會將buffer的數據分成多份給多個消費者,如果一個value已經被一個消費者獲取,那么其他消費者將不會再拿到這個值。這就回答了為什么沒有重復這個問題。
  3. 上面方法同時使用了多任務延續(ContinueWhenAll)對buffer的調用CompleteAdding方法:該方法非常重要,如果沒有調用這個方法,程序會進入死鎖,因為消費者(consumer)會處于一直的等待狀態。

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久综合网hezyo| 久久免费少妇高潮久久精品99| 亚洲男人天堂视频| 国产丝袜精品第一页| 久久躁日日躁aaaaxxxx| 亚洲 日韩 国产第一| 国产成人精品视频在线| 亚洲色图综合久久| 亚洲男人天堂网站| 亚洲精品xxx| 97在线视频免费观看| 久久精品亚洲一区| 日韩欧美在线观看视频| 欧美xxxx综合视频| 欧美国产视频一区二区| 97精品在线观看| 欧美日韩一区二区免费视频| 欧美午夜久久久| 亚洲黄页视频免费观看| 欧美肥婆姓交大片| 日韩精品一二三四区| 丝袜美腿精品国产二区| 国产精品美腿一区在线看| www.99久久热国产日韩欧美.com| 国产精品九九久久久久久久| 亚洲福利精品在线| 精品国产拍在线观看| 午夜精品一区二区三区在线| 日韩欧美精品在线观看| 国产成人免费av电影| 欧美性生交大片免费| 日韩久久精品电影| 国产成人综合精品| 成人中文字幕+乱码+中文字幕| 原创国产精品91| 欧美在线不卡区| 国产成人综合一区二区三区| 亚洲毛片在线免费观看| 日韩欧美在线视频日韩欧美在线视频| 欧美成人免费在线观看| 成人97在线观看视频| 欧美激情免费在线| 日韩av免费看| 91精品久久久久久久久久久久久久| 欧美日韩精品二区| 92版电视剧仙鹤神针在线观看| 国产精品美乳一区二区免费| 国产亚洲精品一区二555| 欧美黄色片免费观看| 欧美性猛交xxxx乱大交极品| 亚洲精品美女久久久久| 亚洲一区二区久久久久久| 亚洲男人天堂手机在线| 欧美性猛交xxxx黑人猛交| 亚洲午夜精品视频| 国产精品久久久久久久久久久新郎| 精品精品国产国产自在线| 亚洲精品久久久久久下一站| 国产精品久久999| 国产日韩视频在线观看| 色婷婷成人综合| 亚洲a级在线播放观看| 亚洲综合自拍一区| 在线精品视频视频中文字幕| 精品国产鲁一鲁一区二区张丽| 成人有码视频在线播放| 久久久久久久久网站| 97超级碰在线看视频免费在线看| 欧美日韩国产一区在线| 精品久久香蕉国产线看观看gif| 日韩中文字幕在线播放| 亚洲精品美女久久| 欧美色另类天堂2015| 懂色av一区二区三区| 精品成人乱色一区二区| 欧美精品在线极品| 一区二区三区黄色| 91理论片午午论夜理片久久| 久久久久久有精品国产| 日韩电影中文字幕| 国产精选久久久久久| 最近中文字幕2019免费| 欧美人与性动交| 欧美亚洲另类制服自拍| 一区国产精品视频| 91tv亚洲精品香蕉国产一区7ujn| 亚洲a∨日韩av高清在线观看| 成人午夜小视频| 亚洲xxx大片| 日韩国产激情在线| 5566成人精品视频免费| 欧美性xxxxx| 亚洲精品成人av| 久久综合久久88| 亚洲欧美日韩精品久久奇米色影视| 在线一区二区日韩| 国产精品人人做人人爽| 午夜精品一区二区三区视频免费看| 日本精品一区二区三区在线| 97免费中文视频在线观看| 欧美日本高清一区| 成人免费直播live| 国产xxx69麻豆国语对白| 国内伊人久久久久久网站视频| 亚洲a级在线播放观看| 亚洲自拍偷拍视频| 一区二区三区视频免费在线观看| 97视频免费在线观看| 影音先锋日韩有码| 精品久久久久久中文字幕大豆网| 欧美亚洲在线播放| 久久91精品国产| 97成人在线视频| 精品视频在线观看日韩| 成人自拍性视频| 91美女福利视频高清| 中文综合在线观看| 亚洲电影av在线| 亚洲精品720p| 亚洲日本aⅴ片在线观看香蕉| 成人免费在线网址| 日韩极品精品视频免费观看| 欧美美最猛性xxxxxx| 91精品国产一区| 中文字幕久热精品在线视频| 欧美高清无遮挡| 欧美壮男野外gaytube| 亚洲国产精品嫩草影院久久| 亚洲久久久久久久久久| 欧洲亚洲妇女av| 欧美极品少妇xxxxⅹ喷水| 福利视频第一区| 日韩免费av在线| 欧美国产乱视频| 一区二区亚洲欧洲国产日韩| www日韩中文字幕在线看| 亚洲天堂成人在线视频| 午夜精品免费视频| 日韩精品极品在线观看播放免费视频| 久久这里有精品| 青草青草久热精品视频在线网站| 国产精品欧美一区二区三区奶水| 国产精品美女久久久久久免费| 成人av电影天堂| 日韩电影中文 亚洲精品乱码| 热re99久久精品国产66热| 91免费电影网站| 不卡av日日日| 久久久97精品| 日韩精品免费一线在线观看| 欧美一级淫片videoshd| 亚洲成人av在线| 日韩精品在线观看一区| 久久久久久久一区二区| 九九热这里只有精品免费看| 亚洲aa在线观看| 上原亚衣av一区二区三区| 欧美极品少妇xxxxⅹ喷水| 亚洲日本成人女熟在线观看| 久久久久久久国产精品| 国产97在线观看| 黑人巨大精品欧美一区二区免费| 日韩精品999| 国产欧美亚洲视频|