成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何在 C# 8 中使用 Channels

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

[[379782]]

本文轉載自微信公眾號「碼農讀書」,作者碼農讀書。轉載本文請聯系碼農讀書公眾號。

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

Dataflow vs Channel

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

為什么要使用 Channels

可以利用 Channels 來實現 生產者和消費者 之間的解耦,大體上有兩個好處:

  • 生產者 和 消費者 是相互獨立的,兩者可以并行執行。
  • 如果生產者不給力,可以創建多個的生產者,如果消費者不給力,可以創建更多的消費者。

總的來說,在 生產者-消費者 模式下可以幫助我們提高應用程序的吞吐率。

安裝 System.Threading.Channels

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

  1. dotnet add package System.Threading.Channels 

創建 channel

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

  • CreateBounded 創建的 channel 是一個有消息上限的通道。
  • CreateUnbounded 創建的 channel 是一個無消息上限的通道。

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

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

對了,Bounded channel 還提供了一個 FullMode 屬性,用于指定當 channel 已滿時該如何對插入的 message 進行處理,通常有四種做法。

  • 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.    } 

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

總的來說,要想使用 生產者-消費者 場景,有幾種實現途徑,比如:BlockingCollection 和 TPL Dataflow,但本篇介紹的 Channels 要比前面的兩種性能更高,關于 Channels 更多的細節,我會在未來的文章中進行討論,如果您現在想急于了解的話,可以參考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

 

責任編輯:武曉燕 來源: 碼農讀書
相關推薦

2021-01-19 05:30:55

C# 8異步流IEnumerable

2021-01-18 05:18:18

C# 8模式C# 7

2021-01-22 05:53:08

C# IndexRange

2021-01-28 05:14:40

C#接口簽名

2020-12-31 07:31:10

C# 反射數據

2021-03-07 16:37:52

C#應用程序

2009-08-04 10:29:06

在C#中使用存儲過程

2021-11-25 00:04:16

C# 插值字符串

2018-08-03 08:37:31

設計模式IT項目GDPR

2022-05-17 08:25:10

TypeScript接口前端

2022-06-23 08:00:53

PythonDateTime模塊

2021-06-09 09:36:18

DjangoElasticSearLinux

2021-03-09 07:27:40

Kafka開源分布式

2015-08-27 09:46:09

swiftAFNetworkin

2024-01-18 08:37:33

socketasyncio線程

2011-08-10 09:31:41

Hibernateunion

2019-09-16 19:00:48

Linux變量

2020-11-30 11:55:07

Docker命令Linux

2014-07-02 09:47:06

SwiftCocoaPods

2020-04-09 10:18:51

Bash循環Linux
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: www.日韩| 精品国产视频 | 成人高清在线 | 亚洲综合99 | 九九久久久 | 亚洲国产精品成人无久久精品 | 国产成人精品免费视频 | 国内精品免费久久久久软件老师 | 亚洲精品黑人 | 精品九九 | 亚洲成人日韩 | 日本公妇乱淫xxxⅹ 国产在线不卡 | 在线日韩在线 | 欧美午夜一区 | 337p日本欧洲亚洲大胆 | 中文字幕国产精品 | 91久久国产 | 在线观看中文字幕亚洲 | 91精品国产一区二区三区 | 日韩欧美一区二区三区 | 黄色毛片在线播放 | 久久久久久中文字幕 | 九九久久精品 | 亚洲视频精品 | 91综合网| 欧美激情一区二区三级高清视频 | 欧美久久久久久久久 | 久草网在线视频 | 亚洲高清视频一区二区 | 国产精品美女久久久久久免费 | 在线亚洲人成电影网站色www | 午夜视频免费网站 | 欧美日韩在线观看一区 | 日本羞羞影院 | 亚洲444kkkk在线观看最新 | 日本三级做a全过程在线观看 | 亚洲综合99 | 日韩欧美一区二区三区免费观看 | 久久精品亚洲 | 成人毛片网站 | 国产亚洲精品久久久久久牛牛 |