架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

搜索
查看: 5115|回复: 3

[资料] .NET Core 高性能队列 Channels 使用

[复制链接]
发表于 2023-5-8 22:11:01 | 显示全部楼层 |阅读模式
System.Threading.Channels 是 .NET Core 3.0 后推出的新的集合类型, 具有异步API,高性能,线程安全等特点,它可以用来做消息队列,进行数据的生产和消费, 公开的 Writer 和 Reader api对应消息的生产者和消费者,也让Channel更加的简洁和易用,与Rabbit MQ 等其他队列不同的是,Channel 是进程内的队列。

.NET/C# 基于 BlockingCollection 后台任务队列
https://www.itsvse.com/thread-9528-1-1.html


System.Threading.Channels 库:超链接登录可见。
Channel<T> 类:超链接登录可见。

Channel 类型

微软提供了两种类型的 channel,一种是有限容量的 bound channel,一种是无限容量的 unbound channel。

创建有限容量的 Channel:Channel.CreateBounded<string>(100);
创建无限容量的 Channel:Channel.CreateUnbounded<string>();

创建无限的 Channel

创建  Channel 时,可以设置 ChannelOptions 的 SingleWriter 和 SingleReader,来指定 Channel 时单一的生产者和消费者,默认都是 false,当设置了 SingleWriter = true 时, 会限制同一个时间只能有一个生产者可以写入数据, SingleReader = true 是同样的。


尝试开启三个生产者线程和一个消费者线程,代码如下:

channel.gif

消费者使用 WaitToReadAsync 等待读取数据。 数据可用后,消费者才会尝试读取数据。


在上面的代码中,消费者都是一条一条的读取数据执行操作,如何让消费者批量消费数据一块处理呢?

新建 ChannelReaderExtensions 扩展,代码如下:


调整消费者代码如下:

channel2.gif

(完)




上一篇:ASP.NET Core(十八)自定义简单的 OutputCache 输出缓存
下一篇:【实战】.NET/C# 离线 IP 地址(归属地)定位库
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
发表于 2023-5-8 22:50:27 | 显示全部楼层
学习学习
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
发表于 2023-5-12 10:07:46 | 显示全部楼层
学习学习
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
发表于 2023-5-16 17:21:37 | 显示全部楼层
学习学习
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2025-6-15 21:30

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表