日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
如何在C#8中使用Channels

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

創(chuàng)新互聯(lián)建站是由多位在大型網(wǎng)絡(luò)公司、廣告設(shè)計(jì)公司的優(yōu)秀設(shè)計(jì)人員和策劃人員組成的一個(gè)具有豐富經(jīng)驗(yàn)的團(tuán)隊(duì),其中包括網(wǎng)站策劃、網(wǎng)頁(yè)美工、網(wǎng)站程序員、網(wǎng)頁(yè)設(shè)計(jì)師、平面廣告設(shè)計(jì)師、網(wǎng)絡(luò)營(yíng)銷人員及形象策劃。承接:網(wǎng)站建設(shè)、成都做網(wǎng)站、網(wǎng)站改版、網(wǎng)頁(yè)設(shè)計(jì)制作、網(wǎng)站建設(shè)與維護(hù)、網(wǎng)絡(luò)推廣、數(shù)據(jù)庫(kù)開(kāi)發(fā),以高性價(jià)比制作企業(yè)網(wǎng)站、行業(yè)門(mén)戶平臺(tái)等全方位的服務(wù)。

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

Dataflow vs Channel

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

為什么要使用 Channels

可以利用 Channels 來(lái)實(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)者。

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

安裝 System.Threading.Channels

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

 
 
 
 
  1. dotnet add package System.Threading.Channels 

創(chuàng)建 channel

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

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

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

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

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

  • Wait
  • DropWrite
  • DropNewest
  • DropOldest

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

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

將消息寫(xiě)入到 channel

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

 
 
 
 
  1. static async Task Main(string[] args) 
  2.        { 
  3.            var channel = Channel.CreateBounded(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(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 中讀寫(xiě) 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(); 
  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 寫(xiě)入到 channel 中的,對(duì)吧。

總的來(lái)說(shuō),要想使用 生產(chǎn)者-消費(fèi)者 場(chǎng)景,有幾種實(shí)現(xiàn)途徑,比如:BlockingCollection 和 TPL Dataflow,但本篇介紹的 Channels 要比前面的兩種性能更高,關(guān)于 Channels 更多的細(xì)節(jié),我會(huì)在未來(lái)的文章中進(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


當(dāng)前名稱:如何在C#8中使用Channels
URL標(biāo)題:http://www.5511xx.com/article/djpciis.html