TPL 之四 BatchBlock

     BatchBlock提供了能够把多个单个的数据组合起来处理的功能,如上图。应对有些需求需要固定多个数据才能处理的问题。在构造函数中需要制定多少个为一个Batch,一旦它收到了那个数量的数据后,会打包放在它的OutputQueue中。当BatchBlock被调用Complete( )告知Post数据结束的时候,会把InputQueue中余下的数据打包放入OutputQueue中等待处理,而不管InputQueue中的数据量是不是满足构造函数的数量。代码地址-BatchBlock1项目

image

image

public static BatchBlock<int> batchBlock = new BatchBlock<int>(3);
public const string DateFormate = "yyyy-MM-dd HH:mm:ss.fff";
public Form1()
{
    InitializeComponent();
}
static int clickCount = 0;
private void btnPost_Click(object sender, EventArgs e)
{
    try
    {
        batchBlock.Post(++clickCount);
        Console.WriteLine($"{DateTime.Now.ToString(DateFormate)} " +
            $"Post  后 Out:{batchBlock.OutputCount} ClickCount:{clickCount}");
    }
    catch (Exception ex)
    {
        Console.WriteLine(ex.Message);
    }
}
private void btnRecive_Click(object sender, EventArgs e)
{
    Console.WriteLine($"{DateTime.Now.ToString(DateFormate)} " +
        $"Recive前 Out:{batchBlock.OutputCount}");
    int[] data;
    //int[] data = batchBlock.Receive();
    bool ret = batchBlock.TryReceive(out data);//输出时为集合类型,将Target队列中的数据N一次性放入到Source队列。
    string str = "";
    if (ret == true)
    {
        foreach (int item in data)
        {
            str = str + item.ToString() + ",";
        }
    }
    Console.WriteLine($"{DateTime.Now.ToString(DateFormate)} " +
        $"Recive后 Out:{batchBlock.OutputCount} 【{str.TrimEnd(',')}】 {ret}");
    batchBlock.Complete();
}

image

posted @   李华丽  阅读(206)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
历史上的今天:
2017-09-11 李华丽博客目录
AmazingCounters.com
点击右上角即可分享
微信分享提示