0

0

c# BlockingCollection 和 Channel 的使用场景和性能对比

煙雲

煙雲

发布时间:2026-01-05 08:17:02

|

459人浏览过

|

来源于php中文网

原创

BlockingCollection适合同步阻塞场景,如CPU密集型后台任务;Channel更适合异步流式处理,支持背压与细粒度控制,资源占用更低。

c# blockingcollection 和 channel 的使用场景和性能对比

BlockingCollection 适合生产者-消费者模型中的同步阻塞场景

当你的业务逻辑明确需要“等待队列有数据才处理”或“队列满时暂停生产”,且不希望引入 async/await 复杂度时,BlockingCollection 是更直接的选择。它底层封装了 ConcurrentQueue(默认)或其它线程安全集合,提供 Take()Add() 的阻塞语义。

常见错误是误用在高吞吐异步 I/O 场景:比如用 Take() 在 ASP.NET Core 请求线程里等数据,会浪费线程资源;或者没设 boundedCapacity 导致内存无限增长。

  • BlockingCollectionTake() 会真实阻塞线程(调用 Monitor.Wait),适用于 CPU 密集型、节奏可控的后台任务,如日志批量写入、消息预处理管道
  • 若需限时等待,必须用 TryTake(out T, int millisecondsTimeout),传 -1 等同于无限制阻塞
  • 构造时传入 new ConcurrentStack() 可改用 LIFO 行为,但要注意这会改变消费顺序,不是所有场景都适用

Channel 更适合异步流式处理和细粒度控制

Channel 是 .NET Core 3.0+ 引入的异步原语,本质是可 await 的生产者-消费者通道,设计目标就是替代“手动管理 TaskCompletionSource + 队列”的模式。它不阻塞线程,而是返回 ValueTaskValueTask,天然契合 async 工作流。

典型误用是把它当成 BlockingCollection 的 async 版直接替换:比如在同步方法里 await channel.Reader.ReadAsync(),结果编译报错——你得确保整个调用链支持异步。

  • 读取端推荐用 await foreach (var item in channel.Reader.ReadAllAsync()),它自动处理完成信号和取消,比手写 while (await reader.WaitToReadAsync()) 更安全
  • 写入端注意 channel.Writer.TryWrite() 返回 bool 表示是否成功(如缓冲区满且为 Bounded Channel 时失败),而 await channel.Writer.WriteAsync() 会 await 直到有空间,可能永久挂起
  • Bounded Channel 的 SingleWriter/SingleReader 配置能显著减少锁竞争,在确定单生产者/单消费者时务必启用

性能差异主要体现在线程占用和缓冲策略上

单纯比“每秒吞吐量”,两者在中低压力下差距不大;真正拉开距离的是资源模型:BlockingCollection 每次 Take() 占一个线程,ChannelReadAsync() 几乎不占线程(靠 IOCP 或计时器唤醒)。这意味着在万级并发连接的网关类应用中,用 Channel 可以把线程数压到几百,而 BlockingCollection 很容易推到上千。

贝特协同办公系统(BetterCOS)
贝特协同办公系统(BetterCOS)

具备更多的新特性: A.具有集成度更高的平台特点,集中体现了信息、文档在办公活动中交流的开放性与即时性的重要。 B.提供给管理员的管理工具,使系统更易于管理和维护。 C.产品本身精干的体系结构再加之结合了插件的设计思想,使得产品为用户度身定制新模块变得非常快捷。 D.支持对后续版本的平滑升级。 E.最价的流程管理功能。 F.最佳的网络安全性及个性化

下载

另一个关键点是缓冲行为:默认 BlockingCollection 无界,容易 OOM;Channel.CreateBounded(capacity) 则强制限流,配合 WaitToWriteAsync() 能实现背压(backpressure)——生产者速度被消费者拖慢时自动减速,这是构建稳定服务的关键。

  • 测试显示:在 1000 并发生产者持续写入场景下,BlockingCollection 线程池增长至 230+,Channel 稳定在 12–18 个活跃线程
  • ChannelReader 支持 Count 属性(仅限 Bounded),而 BlockingCollectionCount 是 O(n) 遍历成本,高频查询要避开
  • 如果业务需要“跳过旧数据”,ChannelReader.TryRead() 可非阻塞尝试读,BlockingCollection 没有等价的无等待接口

选型决策树:先问这三个问题

不用查文档,现场就能判断:

  • 你的消费者逻辑是否必须同步执行(比如调用只能同步的第三方 SDK)?→ 选 BlockingCollection
  • 是否已有大量 async 基础设施(如 IHostedService、gRPC service 方法)?→ 优先 Channel
  • 是否需要精确控制背压、丢弃策略或毫秒级超时(如实时风控要求 50ms 内响应)?→ Channel 提供更细粒度 API,BlockingCollection 只能靠 TryTake 模拟,代码更糙

混合使用也合理:比如用 BlockingCollection 接收硬件传感器的同步回调,再由后台线程批量 drainChannel 进行异步分发。真正的难点不在语法,而在厘清“谁控制节奏、谁承担等待成本”。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

195

2023.11.20

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

83

2023.09.25

php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

40

2025.12.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

314

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

528

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

49

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

193

2025.08.29

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1004

2023.10.19

PPT动态图表制作教程大全
PPT动态图表制作教程大全

本专题整合了PPT动态图表制作相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.07

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号