国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

如何在 C# 8 中使用 Channels

開發(fā) 后端
在面對 生產(chǎn)者-消費(fèi)者 的場景下, netcore 提供了一個(gè)新的命名空間 System.Threading.Channels 來幫助我們更高效的處理此類問題,有了這個(gè) Channels 存在, 生產(chǎn)者 和 消費(fèi)者 可以各自處理自己的任務(wù)而不相互干擾,有利于兩方的并發(fā)處理,這篇文章我們就來討論下如何使用 System.Threading.Channels。

[[379782]]

本文轉(zhuǎn)載自微信公眾號(hào)「碼農(nóng)讀書」,作者碼農(nóng)讀書。轉(zhuǎn)載本文請聯(lián)系碼農(nóng)讀書公眾號(hào)。

 在面對 生產(chǎn)者-消費(fèi)者 的場景下, netcore 提供了一個(gè)新的命名空間 System.Threading.Channels 來幫助我們更高效的處理此類問題,有了這個(gè) Channels 存在, 生產(chǎn)者 和 消費(fèi)者 可以各自處理自己的任務(wù)而不相互干擾,有利于兩方的并發(fā)處理,這篇文章我們就來討論下如何使用 System.Threading.Channels。

Dataflow vs Channel

在 System.Threading.Tasks.Dataflow 命名空間下提供了一個(gè)數(shù)據(jù)流庫,主要封裝了 存儲(chǔ) 和 處理 兩大塊,該庫專注于 pipeline 處理,而 System.Threading.Tasks.Channels 主要專注于 存儲(chǔ) 這塊,從單一職責(zé)上來說,在 生產(chǎn)者-消費(fèi)者 場景下,Channels 比 Dataflow 性能要高得多。

為什么要使用 Channels

可以利用 Channels 來實(shí)現(xiàn) 生產(chǎn)者和消費(fèi)者 之間的解耦,大體上有兩個(gè)好處:

  • 生產(chǎn)者 和 消費(fèi)者 是相互獨(dú)立的,兩者可以并行執(zhí)行。
  • 如果生產(chǎn)者不給力,可以創(chuàng)建多個(gè)的生產(chǎn)者,如果消費(fèi)者不給力,可以創(chuàng)建更多的消費(fèi)者。

總的來說,在 生產(chǎn)者-消費(fèi)者 模式下可以幫助我們提高應(yīng)用程序的吞吐率。

安裝 System.Threading.Channels

要想使用 Channel,需要用 nuget 引用 System.Threading.Channels 包,還可以通過 Visual Studio 2019 的 NuGet package manager 可視化界面安裝 或者 通過 NuGet package manager 命令行工具輸入以下命令:

  1. dotnet add package System.Threading.Channels 

創(chuàng)建 channel

本質(zhì)上來說,你可以創(chuàng)建兩種類型的 channel,一種是有限容量的 bound channel,一種是無限容量的 unbound channel,接下來的問題是,如何創(chuàng)建呢?Channels 提供了兩種 工廠方法 用于創(chuàng)建,如下代碼所示:

  • CreateBounded 創(chuàng)建的 channel 是一個(gè)有消息上限的通道。
  • CreateUnbounded 創(chuàng)建的 channel 是一個(gè)無消息上限的通道。

下面的代碼片段展示了如何創(chuàng)建 unbounded channel,并且只能存放 string 類型。

  1. static void Main(string[] args) 
  2.        { 
  3.            var channel = Channel.CreateUnbounded<string>(); 
  4.        } 

對了,Bounded channel 還提供了一個(gè) FullMode 屬性,用于指定當(dāng) channel 已滿時(shí)該如何對插入的 message 進(jìn)行處理,通常有四種做法。

  • Wait
  • DropWrite
  • DropNewest
  • DropOldest

下面的代碼片段展示了如何在 Bounded channel 上使用 FullMode。

  1. static void Main(string[] args) 
  2.       { 
  3.           var channel = Channel.CreateBounded<string>(new BoundedChannelOptions(1000) 
  4.           { 
  5.               FullMode = BoundedChannelFullMode.Wait 
  6.           }); 
  7.       } 

將消息寫入到 channel

要想將 message 寫入到 channel,可以使用 WriteAsync() 方法,如下代碼所示:

  1. static async Task Main(string[] args) 
  2.        { 
  3.            var channel = Channel.CreateBounded<string>(new BoundedChannelOptions(1000) 
  4.            { 
  5.                FullMode = BoundedChannelFullMode.Wait 
  6.            }); 
  7.  
  8.            await channel.Writer.WriteAsync("Hello World!"); 
  9.        } 

從 channel 中讀取消息

要想從 channel 中讀取 message,可以使用 ReadAsync(),如下代碼所示:

  1. static async Task Main(string[] args) 
  2.        { 
  3.            var channel = Channel.CreateBounded<string>(new BoundedChannelOptions(1000) 
  4.            { 
  5.                FullMode = BoundedChannelFullMode.Wait 
  6.            }); 
  7.  
  8.            while (await channel.Reader.WaitToReadAsync()) 
  9.            { 
  10.                if (channel.Reader.TryRead(out var message)) 
  11.                { 
  12.                    Console.WriteLine(message); 
  13.                } 
  14.            } 
  15.        } 

System.Threading.Channels 例子

下面是完整的代碼清單,展示了如何從 channel 中讀寫 message。

  1. class Program 
  2.    { 
  3.        static async Task Main(string[] args) 
  4.        { 
  5.            await SingleProducerSingleConsumer(); 
  6.  
  7.            Console.ReadKey(); 
  8.        } 
  9.  
  10.        public static async Task SingleProducerSingleConsumer() 
  11.        { 
  12.            var channel = Channel.CreateUnbounded<int>(); 
  13.            var reader = channel.Reader; 
  14.            for (int i = 0; i < 10; i++) 
  15.            { 
  16.                await channel.Writer.WriteAsync(i + 1); 
  17.            } 
  18.  
  19.            while (await reader.WaitToReadAsync()) 
  20.            { 
  21.                if (reader.TryRead(out var number)) 
  22.                { 
  23.                    Console.WriteLine(number); 
  24.                } 
  25.            } 
  26.        } 
  27.    } 

可以看到,控制臺(tái)中輸出了數(shù)字 1-10,這些數(shù)字正是 Writer 寫入到 channel 中的,對吧。

總的來說,要想使用 生產(chǎn)者-消費(fèi)者 場景,有幾種實(shí)現(xiàn)途徑,比如:BlockingCollection 和 TPL Dataflow,但本篇介紹的 Channels 要比前面的兩種性能更高,關(guān)于 Channels 更多的細(xì)節(jié),我會(huì)在未來的文章中進(jìn)行討論,如果您現(xiàn)在想急于了解的話,可以參考MSDN:https://docs.microsoft.com/en-us/dotnet/api/system.threading.channels?view=netcore-3.0

譯文鏈接:https://www.infoworld.com/article/3445156/how-to-use-systemthreadingchannels-in-net-core.html

 

責(zé)任編輯:武曉燕 來源: 碼農(nóng)讀書
相關(guān)推薦

2021-01-18 05:18:18

C# 8模式C# 7

2021-01-19 05:30:55

C# 8異步流IEnumerable

2021-01-28 05:14:40

C#接口簽名

2021-01-22 05:53:08

C# IndexRange

2020-12-31 07:31:10

C# 反射數(shù)據(jù)

2021-03-07 16:37:52

C#應(yīng)用程序

2009-08-04 10:29:06

在C#中使用存儲(chǔ)過程

2021-11-25 00:04:16

C# 插值字符串

2018-08-03 08:37:31

設(shè)計(jì)模式IT項(xiàng)目GDPR

2022-06-23 08:00:53

PythonDateTime模塊

2011-08-10 09:31:41

Hibernateunion

2021-03-09 07:27:40

Kafka開源分布式

2022-05-17 08:25:10

TypeScript接口前端

2021-06-09 09:36:18

DjangoElasticSearLinux

2015-08-27 09:46:09

swiftAFNetworkin

2024-01-18 08:37:33

socketasyncio線程

2019-09-16 19:00:48

Linux變量

2014-07-02 09:47:06

SwiftCocoaPods

2024-09-06 11:34:15

RustAI語言

2020-11-30 11:55:07

Docker命令Linux
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

欧美性猛交xxxxxx富婆| 免费网站www在线观看| 91视视频在线直接观看在线看网页在线看| 石原莉奈一区二区三区高清在线| 欧美一级午夜免费电影| 91麻豆精品国产91久久久久推荐资源| 99中文视频在线| av不卡一区二区三区| 国产在线视频网址| 欧美另类老女人| 日本va欧美va精品发布| 久草在线官网| 久久综合免费视频| 欧美一级二区| 在线视频国产福利| 日韩中文字幕在线免费观看| 国产精品伦理久久久久久| 亚洲精品蜜桃久久久久久| 欧美性猛交xxxx| 国产精品欧美大片| 久久香蕉视频网站| 宅男在线国产精品| 欧美激情另类| 性刺激的欧美三级视频| 欧美精品一区二区三区视频| 久久神马影院| 日本xxxxxx| 自拍偷拍亚洲区| 日本亚洲最大的色成网站www| 天堂在线视频| 久久久久久久一区二区| 国产成人在线视频网址| 麻豆视频在线观看免费网站| 国产精品福利在线观看网址| 久久先锋影音av鲁色资源网| 一级毛片久久久| 色一情一乱一伦一区二区三区| 午夜肉伦伦影院| 欧美一二三在线| 欧美大片一区| 未来日记在线观看| 欧美另类xxx| 国产精品白丝jk黑袜喷水| 五月综合网站| 国产精品9999| 国产成人av影院| jizz日韩| 黄网站免费在线播放| 久久99精品久久久久久青青91| 久久精品国产成人一区二区三区| 3p视频在线观看| 91福利入口| 一本一道久久a久久精品综合蜜臀| 成人高清av| 欧美白嫩的18sex少妇| 国产成人精品免高潮在线观看| 国产精品久久777777| 99久久婷婷国产综合精品青牛牛| 久久久久狠狠高潮亚洲精品| 久久精品最新地址| 久久久久久毛片| 中文字幕一区二区三区中文字幕| 国产精品亚洲a| 久久久亚洲成人| 亚洲激情在线播放| 欧美丰满日韩| 川上优的av在线一区二区| 亚洲最大福利视频| 欧美三级韩国三级日本一级| 在线免费高清一区二区三区| 国产大片在线免费观看| 精品国产乱码久久久久久88av| 欧美精品自拍偷拍| 麻豆91精品91久久久的内涵| 欧美国产大片| 可以免费观看av毛片| 蜜臀久久99精品久久久久久宅男 | 国产精品wwwww| 欧美视频一区二区三区在线观看| 999精品一区| 三级视频网站在线| 肥熟一91porny丨九色丨| 欧美久久一区二区| 九九视频精品免费| 成人影院在线免费观看| 国产免费黄视频| 欧美亚洲国产视频小说| 亚洲国产一区二区a毛片| 亚洲蜜桃视频| 国产91在线视频蝌蚪| 性欧美18一19内谢| 日韩在线小视频| 一区二区三区四区在线| 国产在线不卡| 欧美成人ⅴideosxxxxx| 粗暴91大变态调教| 91精品视频免费看| 亚洲精品v欧美精品v日韩精品| 久久亚洲一区二区三区明星换脸| 偷拍一区二区| 欧美jizzhd69巨大| 国产一区二区网| 国产女同一区二区| 亚洲国模精品私拍| 中文字幕亚洲欧美在线不卡| 亚洲精品日本| 电影一区中文字幕| 好男人免费精品视频| 亚洲v国产v在线观看| 久久777国产线看观看精品| 欧美日韩激情视频| 国产精品一区免费视频| 国产99久久精品一区二区300| 成人网视频在线观看| 污污污污污污www网站免费| 欧美一区二区色| 欧美变态tickle挠乳网站| 欧美激情一区二区在线| 一本不卡影院| 亚洲一区二区三区在线免费| 99se视频在线观看| 午夜dv内射一区二区| 精品国产乱码久久久久久蜜柚| 久久影视电视剧免费网站| 欧美探花视频资源| 国产欧美视频在线观看| 99成人免费视频| 操欧美女人视频| 色呦呦网站在线观看| 大胆高清日本a视频| 中文字幕免费在线不卡| 国产中文字幕91| 久久精品青青大伊人av| 欧美日韩国产在线观看| 亚洲欧洲av另类| 国产精品一区三区| 亚洲欧洲视频| 国产伦精品一区二区三区千人斩| 婷婷综合六月| 日韩美女网站| 成人福利视频导航| 97视频在线免费播放| 免费毛片一区二区三区久久久| 日本亚洲欧洲色α| 亚洲男人第一网站| 91精品办公室少妇高潮对白| 久久久不卡网国产精品二区| 日本成人在线电影网| 欧美gvvideo网站| 人人爱人人干婷婷丁香亚洲| xxxx成人| avtt在线播放| 中文字幕乱在线伦视频乱在线伦视频| 99热自拍偷拍| 亚洲欧洲精品在线观看| 国产精品乱子乱xxxx| 国产精品成人在线| 欧美激情国产高清| 国产亚洲精品日韩| 亚洲第一综合天堂另类专| 欧美日韩一本到| 欧美日韩中文在线| 亚洲伊人色欲综合网| 中文字幕精品—区二区四季| 波多野洁衣一区| 国产精品亚洲午夜一区二区三区 | 国产精品青青草| 国产99久久精品一区二区| 精品国产网站地址| 日韩av网站导航| 日韩色在线观看| 在线观看免费一区| 亚洲.国产.中文慕字在线| 国产视频在线观看一区二区三区| 国产精品1区二区.| 久久99国产精品尤物| 日韩电影在线观看一区| 亚洲精华国产欧美| 欧美视频成人| 欧美1区2区3区| 青青草综合网| 国产精品欧美在线观看| 奇米影视777在线欧美电影观看| 粉嫩av国产一区二区三区| 日本综合视频| 欧美专区福利免费| 成人在线爆射| 亚洲精品国产嫩草在线观看| 欧美freesex| 国产精品第一| 精品欧美国产一区二区三区不卡| 免费国产黄色网址| 国产有码在线| 亚洲三级在线| 久久电影国产免费久久电影| 亚洲午夜精品网| 中文字幕亚洲色图| 日本一区免费| 国内在线精品| 国产精品入口久久|