HowTo:使用数据流读写消息
本文主要演示使用TPL 数据流库从数据流块(dataflow block)读写消息。
提供了同步方法和异步方法。
主要使用BufferBlock,其既能作为message source,有能作为message target。
- Install-Package Microsoft.Tpl.Dataflow
- using System.Threading.Tasks.Dataflow;
1.同步方法读写消息
1.1 分别使用Post和Receive方法进行读写。
- public
void SynchronouslyPostAndReceive() - {
- var bufferBlock = new BufferBlock<int>();
- for (int i = 0; i < 3; i++)
- {
- bufferBlock.Post(i);
- }
- for (int i = 0; i < 3; i++)
- {
- Console.WriteLine(bufferBlock.Receive());
- }
- }
输出:
0
1
2
解释:

从Post方法可以看出,此时BufferBlock扮演着ITargetBlock的角色;
同理,Receive方法调用时,BufferBlock扮演着ISourceBlock的角色;
这也就证明了BufferBlock同时用作Target和Source。已可以看出,同步的时候,BufferBlock实际上是FIFO。
1.2 使用TryReceive来读取
- public
void SynchronouslyPostAndReceive() - {
- var bufferBlock = new BufferBlock<int>();
- for (int i = 0; i < 3; i++)
- {
- bufferBlock.Post(i);
- }
- //for (int i = 0; i < 3; i++)
- //{
- // Console.WriteLine(bufferBlock.Receive());
- //}
- int
value; - while (bufferBlock.TryReceive(out
value)) - {
- Console.WriteLine(value);
- }
- }
输出:
0
1
2
1.3并发读写
使用Task,将读写放在不同的线程。
当Receive,且无数据时,则会阻塞。
- public
void ConcurrentlyPostAndReceive() - {
- var bufferBlock = new BufferBlock<int>();
- var post01 = Task.Run(() =>
- {
- bufferBlock.Post(1);
- bufferBlock.Post(2);
- bufferBlock.Post(3);
- bufferBlock.Post(4);
- });
- var receive = Task.Run(() =>
- {
- for (int i = 0; i < 6; i++)
- {
- Console.WriteLine(bufferBlock.Receive());
- }
- });
- var post02 = Task.Run(() =>
- {
- bufferBlock.Post(5);
- bufferBlock.Post(6);
- });
- Task.WaitAll(post01, receive, post02);
- }
输出:
5
1
2
3
4
6
2.异步方式读写消息
主要是TAP的一种套用。使用async 和await来实现。
- static async Task AsyncSendReceive(BufferBlock<int> bufferBlock)
- {
- // Post more messages to the block asynchronously.
- for (int i = 0; i < 3; i++)
- {
- await bufferBlock.SendAsync(i);
- }
- // Asynchronously receive the messages back from the block.
- for (int i = 0; i < 3; i++)
- {
- Console.WriteLine(await bufferBlock.ReceiveAsync());
- }
- }
- public
void Start() - {
- AsyncSendReceive(new BufferBlock<int>()).Wait();
- }
HowTo:使用数据流读写消息的更多相关文章
- HDFS的数据流读写数据 (面试开发重点)
1 HDFS写数据流程 1.1 剖析文件写入 HDFS写数据流程,如图所示 1)客户端通过Distributed FileSystem模块向NameNode请求上传文件,NameNode检查目标文件是 ...
- 队列Queue:任务间的消息读写,安排起来~
摘要:本文通过分析鸿蒙轻内核队列模块的源码,掌握队列使用上的差异. 本文分享自华为云社区<鸿蒙轻内核M核源码分析系列十三 消息队列Queue>,作者:zhushy . 队列(Queue)是 ...
- 分布式消息队列 Kafka
分布式消息队列 Kafka 2016-02-25 杜亦舒 Kafka是一个高吞吐量的.分布式的消息系统,由Linkedin开发,开发语言为scala具有高吞吐.可扩展.分布式等特点 适用场景 活动数据 ...
- System V IPC(1)-消息队列
一.概述 System V三种IPC:消息队列,信号量,共享内存.这三种IPC最先出现在AT&am ...
- 【转】快速理解Kafka分布式消息队列框架
from:http://blog.csdn.net/colorant/article/details/12081909 快速理解Kafka分布式消息队列框架 标签: kafkamessage que ...
- 快速理解Kafka分布式消息队列框架
作者:刘旭晖 Raymond 转载请注明出处 Email:colorant at 163.com BLOG:http://blog.csdn.net/colorant/ ==是什么 == 简单的说,K ...
- Kafka分布式消息模型
Kafka开发的主要初衷目标是构建一个用来处理海量日志,用户行为和网站运营统计等的数据处理框架.在结合了数据挖掘,行为分析,运营监控等需求的情况下,需要能够满足各种实时在线和批量离线处理应用场合对低延 ...
- 使用JDK自带的MessageDigest计算消息摘要
使用JDK自带的MessageDigest计算消息摘要 上代码 /** * 使用JDK自带MessageDigest */ public class MessageDigestUtils { /** ...
- [转载] 快速理解Kafka分布式消息队列框架
转载自http://blog.csdn.net/xiaolang85/article/details/18048631 ==是什么 == 简单的说,Kafka是由Linkedin开发的一个分布式的消息 ...
随机推荐
- September 20th 2016 Week 39th Tuesday
Failure is not fatal, but failure to change might be. 失败并不致命,但无法改变却可能是致命的. I need change, but it see ...
- vs c++系统函数 计时器和暂停
在vs console下, 1 添加计时器 #include <Windows.h> double start = GetTickCount(); double end = GetTick ...
- SQLServer基本操作
SQL 全名是结构化查询语言(Structured Query Language),是关系数据库管理系统的标准语言 1.分离数据库:将当前数据库文件和数据库引擎的关系断开,没有任何关系了,这样就可以随 ...
- elipse插件整理
整理一下用过的eclipse插件: 1. WindowBuilder :swing插件,可以拖啊拖啊拖出来一个窗口,可以显著提高开发效率. 官网: http://www.eclipse.org/w ...
- EventBus学习入门
EventBus Features What makes greenrobot's EventBus unique, are its features: Simple yet powerful: Ev ...
- hdu 2020
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2020 思路:优先队列水过priority_queue #include <cstdio> ...
- [LeetCode] Min Stack
Design a stack that supports push, pop, top, and retrieving the minimum element in constant time. pu ...
- POJ2762 Going from u to v or from v to u(单连通 缩点)
判断图是否单连通,先用强连通分图处理,再拓扑排序,需注意: 符合要求的不一定是链拓扑排序列结果唯一,即在队列中的元素始终只有一个 #include<cstdio> #include< ...
- ORA-03113:通信通道的文件结尾解决
今天跟往常一样,登陆PL/SQL,确登陆失败,出现一个错误“ORA-01034”和“ORA-27101”如图: 然后就就通过命令提示符去登陆Oracle,去查看怎么回事,然后问题进一步出现,错误“OR ...
- jquery判断当前设备是手机还是电脑并跳转
<script type="text/javascript"> var commonURL = 'http://xxxx.com/'; function mobile_ ...