精品秘无码一区二区三区老师-精品秘一区二三区免费雷安-精品蜜桃秘一区二区三区-精品蜜桃秘一区二区三区粉嫩-精品蜜桃一区二区三区-精品蜜臀国产aⅴ一区二区三区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

如何在 C# 8 中使用 Channels

admin
2024年12月9日 22:24 本文熱度 567

在面對  生產者-消費者 的場景下, 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 命令行工具輸入以下命令:


dotnet add package System.Threading.Channels

創建 channel

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

  • CreateBounded<T> 創建的 channel 是一個有消息上限的通道。

  • CreateUnbounded<T> 創建的 channel 是一個無消息上限的通道。

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


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

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

  • Wait

  • DropWrite

  • DropNewest

  • DropOldest

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


        static void Main(string[] args)
        {
            var channel = Channel.CreateBounded<string>(new BoundedChannelOptions(1000)
            {
                FullMode = BoundedChannelFullMode.Wait
            });
        }

將消息寫入到 channel

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


        static async Task Main(string[] args)
        {
            var channel = Channel.CreateBounded<string>(new BoundedChannelOptions(1000)
            {
                FullMode = BoundedChannelFullMode.Wait
            });

            await channel.Writer.WriteAsync("Hello World!");
        }

從 channel 中讀取消息

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


        static async Task Main(string[] args)
        {
            var channel = Channel.CreateBounded<string>(new BoundedChannelOptions(1000)
            {
                FullMode = BoundedChannelFullMode.Wait
            });

            while (await channel.Reader.WaitToReadAsync())
            {
                if (channel.Reader.TryRead(out var message))
                {
                    Console.WriteLine(message);
                }
            }
        }

System.Threading.Channels 例子

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


    class Program
    {
        static async Task Main(string[] args)
        {
            await SingleProducerSingleConsumer();

            Console.ReadKey();
        }

        public static async Task SingleProducerSingleConsumer()
        {
            var channel = Channel.CreateUnbounded<int>();
            var reader = channel.Reader;
            for (int i = 0; i < 10; i++)
            {
                await channel.Writer.WriteAsync(i + 1);
            }

            while (await reader.WaitToReadAsync())
            {
                if (reader.TryRead(out var number))
                {
                    Console.WriteLine(number);
                }
            }
        }
    }

可以看到,控制臺中輸出了數字 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


該文章在 2024/12/10 12:22:42 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 麻豆精品在线视频 | 综合永久入口 | 国产激情无码视频在线播放性色 | 亚洲自偷精品视频自拍 | 国产欧美日产激情视频 | 一本道道香蕉a | 一本久道久久综合婷婷五月 | 亚洲精品日韩av片在线观看 | 中文字幕一区二区在线观看 | 毛片免费全部免费观看 | 久久成人精品国产免费看 | 亚洲精品美女久久7777777 | 国产成人毛片 | 最新国产精品无码 | 国产99久久精品一区二区 | 被绑在坐桩机上抹春药 | 亚洲精品久久久久久中女字幕 | 色欲色香天天天综合网www | 免费一区二区无码东京热 | 大尺度做爰啪啪高潮床戏 | 无码成人片一区二区三区 | 亚洲校园春色另类激情高清电影在线播放 | 免费一区二区无码东京热 | 国产69精品久久久久人妻 | 国语自产偷拍精品视频偷拍 | 国产偷窥熟妇高潮呻吟 | 欧洲色图片依依发 | 国产精品日韩av在线播放 | 无码v网址在线免费观看 | 国产成人无码精品久久二区三区 | 亚洲中文字幕久久精品无码app | 无码写真精品永久福利在线 | 99国产精品久久久久久久久久久 | 亚洲中文字幕久久精品无码VA | 亚洲中文字幕宗合网 | 天堂av无码av一区二区三区 | 无码人妻少妇久久中文字幕 | 天美一二三传媒免费观看 | 亚洲午夜精品久久久久久抢 | 国产精品点击进入在线影院高清 | 蜜臀AV精品一区二区三区 |