本文主要演示使用TPL 数据流库从数据流块(dataflow block)读写消息。

提供了同步方法和异步方法。

主要使用BufferBlock,其既能作为message source,有能作为message target。

  1. Install-Package Microsoft.Tpl.Dataflow
  2.  
  3. using System.Threading.Tasks.Dataflow;

 

1.同步方法读写消息

 

1.1 分别使用Post和Receive方法进行读写。

  1. public
    void SynchronouslyPostAndReceive()
  2. {
  3.     var bufferBlock = new BufferBlock<int>();
  4.  
  5.     for (int i = 0; i < 3; i++)
  6.     {
  7.         bufferBlock.Post(i);
  8.     }
  9.  
  10.     for (int i = 0; i < 3; i++)
  11.     {
  12.         Console.WriteLine(bufferBlock.Receive());
  13.     }
  14. }

输出:

0

1

2

解释:

 

从Post方法可以看出,此时BufferBlock扮演着ITargetBlock的角色;

同理,Receive方法调用时,BufferBlock扮演着ISourceBlock的角色;

这也就证明了BufferBlock同时用作Target和Source。已可以看出,同步的时候,BufferBlock实际上是FIFO。

 

1.2 使用TryReceive来读取

  1. public
    void SynchronouslyPostAndReceive()
  2. {
  3.     var bufferBlock = new BufferBlock<int>();
  4.  
  5.     for (int i = 0; i < 3; i++)
  6.     {
  7.         bufferBlock.Post(i);
  8.     }
  9.  
  10.     //for (int i = 0; i < 3; i++)
  11.     //{
  12.     // Console.WriteLine(bufferBlock.Receive());
  13.     //}
  14.  
  15.     int
    value;
  16.     while (bufferBlock.TryReceive(out
    value))
  17.     {
  18.         Console.WriteLine(value);
  19.     }
  20. }

输出:

0

1

2

1.3并发读写

使用Task,将读写放在不同的线程。

当Receive,且无数据时,则会阻塞。

  1. public
    void ConcurrentlyPostAndReceive()
  2. {
  3.     var bufferBlock = new BufferBlock<int>();
  4.     var post01 = Task.Run(() =>
  5.     {
  6.         bufferBlock.Post(1);
  7.         bufferBlock.Post(2);
  8.         bufferBlock.Post(3);
  9.         bufferBlock.Post(4);
  10.     });
  11.  
  12.     var receive = Task.Run(() =>
  13.     {
  14.         for (int i = 0; i < 6; i++)
  15.         {
  16.             Console.WriteLine(bufferBlock.Receive());
  17.         }
  18.     });
  19.  
  20.     var post02 = Task.Run(() =>
  21.     {
  22.         bufferBlock.Post(5);
  23.         bufferBlock.Post(6);
  24.     });
  25.  
  26.     Task.WaitAll(post01, receive, post02);
  27. }

输出:

5

1

2

3

4

6

2.异步方式读写消息

 

主要是TAP的一种套用。使用async 和await来实现。

 

  1. static async Task AsyncSendReceive(BufferBlock<int> bufferBlock)
  2. {
  3.     // Post more messages to the block asynchronously.
  4.     for (int i = 0; i < 3; i++)
  5.     {
  6.         await bufferBlock.SendAsync(i);
  7.     }
  8.  
  9.     // Asynchronously receive the messages back from the block.
  10.     for (int i = 0; i < 3; i++)
  11.     {
  12.         Console.WriteLine(await bufferBlock.ReceiveAsync());
  13.     }
  14.  
  15. }
  16.  
  17. public
    void Start()
  18. {
  19.     AsyncSendReceive(new BufferBlock<int>()).Wait();
  20. }

HowTo:使用数据流读写消息的更多相关文章

  1. HDFS的数据流读写数据 (面试开发重点)

    1 HDFS写数据流程 1.1 剖析文件写入 HDFS写数据流程,如图所示 1)客户端通过Distributed FileSystem模块向NameNode请求上传文件,NameNode检查目标文件是 ...

  2. 队列Queue:任务间的消息读写,安排起来~

    摘要:本文通过分析鸿蒙轻内核队列模块的源码,掌握队列使用上的差异. 本文分享自华为云社区<鸿蒙轻内核M核源码分析系列十三 消息队列Queue>,作者:zhushy . 队列(Queue)是 ...

  3. 分布式消息队列 Kafka

    分布式消息队列 Kafka 2016-02-25 杜亦舒 Kafka是一个高吞吐量的.分布式的消息系统,由Linkedin开发,开发语言为scala具有高吞吐.可扩展.分布式等特点 适用场景 活动数据 ...

  4. System V IPC(1)-消息队列

    一.概述                                                    System V三种IPC:消息队列,信号量,共享内存.这三种IPC最先出现在AT&am ...

  5. 【转】快速理解Kafka分布式消息队列框架

     from:http://blog.csdn.net/colorant/article/details/12081909 快速理解Kafka分布式消息队列框架 标签: kafkamessage que ...

  6. 快速理解Kafka分布式消息队列框架

    作者:刘旭晖 Raymond 转载请注明出处 Email:colorant at 163.com BLOG:http://blog.csdn.net/colorant/ ==是什么 == 简单的说,K ...

  7. Kafka分布式消息模型

    Kafka开发的主要初衷目标是构建一个用来处理海量日志,用户行为和网站运营统计等的数据处理框架.在结合了数据挖掘,行为分析,运营监控等需求的情况下,需要能够满足各种实时在线和批量离线处理应用场合对低延 ...

  8. 使用JDK自带的MessageDigest计算消息摘要

    使用JDK自带的MessageDigest计算消息摘要 上代码 /** * 使用JDK自带MessageDigest */ public class MessageDigestUtils { /** ...

  9. [转载] 快速理解Kafka分布式消息队列框架

    转载自http://blog.csdn.net/xiaolang85/article/details/18048631 ==是什么 == 简单的说,Kafka是由Linkedin开发的一个分布式的消息 ...

随机推荐

  1. 让div等块级元素水平以及垂直居中的解决办法

    一.背景 我们在设计页面的时候,经常要把div等块级元素居中显示,而且是相对页面窗口水平和垂直方向居中显示,如让登录窗口居中显示.我们传统解决的办法是用纯CSS来让div等块级元素居中.在本文中,我将 ...

  2. NYOJ926(概率)

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=926 设最终A获胜的概率为P,则B获胜的概率为1-P: 因此我们只需要考虑A获胜的概率即可 ...

  3. centos 安装 py pyhs2

    1. yum install gcc-c++ cyrus-sasl-develpip2.7 install pyhs2 --->好像不行,在试试 用于 hive thrift 访问 2. os. ...

  4. .net学习笔记---webconfig的读与写

    System.ConfigurationManager类用于对配置文件的读取.其具有的成员如下: 一.AppSettings AppSetting是最简单的配置节,读写非常简单. 名称 说明 AppS ...

  5. SQLServer索引

    SQLServer索引1.聚集和非聚集索引聚集索引:根据聚集索引进行排序,非聚集索引因为不根据索引键排序,所以聚集索引比非聚集索引快(一个表只有一个聚集索引)2.唯一索引和非唯一索引唯一索引时值不能重 ...

  6. 使用Timer和ScheduledThreadPoolExecutor执行定时任务

    Java使用Timer和ScheduledThreadPoolExecutor执行定时任务 定时任务是在指定时间执行程序,或周期性执行计划任务.Java中实现定时任务的方法有很多,主要JDK自带的一些 ...

  7. c#将http调用返回额json中的有关中文的unicode转换为中文(转)

    转转地址:http://www.cnblogs.com/promise-7/archive/2012/11/05/2755515.html 中文转Unicode:HttpUtility.UrlEnco ...

  8. JS手机浏览器判断(转)

    整理查询一下,js判断手机浏览器的方法 <script type="text/javascript"> /* * 智能机浏览器版本信息:包括微信内置 * */ var ...

  9. 拷贝,集合,函数,enumerate,内置函数

    1.拷贝 字符串和数字.赋值 id一样 import copy #提供拷贝功能 copy.copy() #原来的和现在的一起修改,不用修改时用浅copy,节省内存,复制最外层 copy.deepcop ...

  10. 学习SQLAlchemy Core

    有时间了就要慢慢看,死守DJANGO ORM,明显没有SQLAlchemy有优势. 因为SQLAlchemy针对整个PYTHON都是有用的. 找了本书,慢慢撸. <Essential.SQLAl ...