0

0

c# TPL Dataflow 是什么 c#数据流管道怎么用

星降

星降

发布时间:2026-01-13 12:16:47

|

623人浏览过

|

来源于php中文网

原创

最简数据流管道需三步:定义块→LinkTo链接→Post或SendAsync输入数据;如TransformBlock实现乘2减1,LinkTo单向连接,Post非阻塞入队,SendAsync等待接收。

c# tpl dataflow 是什么 c#数据流管道怎么用

TPL Dataflow 是 .NET 原生的异步数据流处理库,不是“另一个队列封装”,而是专为构建可伸缩、带背压、拓扑灵活的并发流水线设计的底层原语。它不依赖你手动管理线程或 Task 调度,而是通过 Block 之间的消息传递自动协调并发、缓冲、完成和错误传播。

怎么创建一个最简可用的数据流管道?

核心是三步:定义块 → 链接(LinkTo)→ 输入数据(PostSendAsync)。下面是一个整数乘2再减1的两级流水线:

var multiply = new TransformBlock(x => x * 2);
var subtract = new TransformBlock(x => x - 1);

multiply.LinkTo(subtract); // 数据从 multiply 流向 subtract

multiply.Post(5); // 输入 5 → 输出 9(5×2−1)

无界AI
无界AI

一站式AI创作、搜索、分享服务

下载

// 等待结果 Console.WriteLine(subtract.ReceiveAsync().Result); // 输出 9

  • LinkTo 是单向、不可逆的连接;调用后,multiply 的输出会自动推给 subtract
  • Post() 是同步非阻塞写入,返回 bool 表示是否成功入队(受 BoundedCapacity 限制)
  • 若需等待写入完成(比如确认下游已接收),改用 await multiply.SendAsync(5)

为什么不用 BufferBlock 直接传数据,而要用 TransformBlock

BufferBlock 只是“中转站”,不处理数据;TransformBlock 才是真正干活的“处理单元”。常见误用是把所有逻辑堆在 ActionBlock 里,结果无法链式复用、难以测试、丢失类型流。

  • 想做“转换”(如 stringJsonElement)、“计算”、“校验”,必须用 TransformBlock
  • 想做“副作用”(如写 DB、发 HTTP、打日志),才用 ActionBlock,且它没有输出,链路在此终止
  • BufferBlock 最适合做“解耦缓冲”或“动态路由前哨”,比如接上游不定速生产者,再用 LinkTo 分发到多个 TransformBlock

MaxDegreeOfParallelismBoundedCapacity 怎么配才不崩?

这两个参数直接决定吞吐、延迟和内存安全。设错会导致死锁、OOM 或完全串行化——不是“越大越好”。

  • MaxDegreeOfParallelism = 1(默认):块内逻辑串行执行,天然线程安全,适合有状态或顺序敏感操作(如按 ID 保序处理)
  • MaxDegreeOfParallelism > 1:启用并行,但要求处理函数是纯函数(无共享状态),否则需自行加锁
  • BoundedCapacity = n:限制 Block 内部队列长度。设为 1 时,Post() 会立即返回 false(背压生效);设为 0 则禁用内部缓冲,强制同步等待消费者空闲
  • 典型组合:new ExecutionDataflowBlockOptions { MaxDegreeOfParallelism = 4, BoundedCapacity = 100 }

真正难的不是搭出一条管道,而是让多条管道之间能条件分流、错误隔离、优雅完成。比如一个 BroadcastBlock 同时喂给过滤块和审计块,其中一个失败不能拖垮另一个——这需要显式配置 PropagateCompletion = false 和独立的 Fault() 处理。这些细节,不踩几次 InvalidOperationException: The source block has been completed 是意识不到的。

相关专题

更多
string转int
string转int

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

315

2023.08.02

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

387

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

571

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

480

2023.08.10

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

331

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

403

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

1672

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1962

2024.08.16

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.2万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

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

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