System.Threading.Tasks.Dataflow 9.0.7

About

Provides dataflow components that are collectively referred to as the TPL Dataflow Library. This dataflow model promotes actor-based programming by providing in-process message passing for coarse-grained dataflow and pipelining tasks.

Key Features

  • Foundation for message passing and parallelizing CPU-intensive and I/O-intensive applications that have high throughput and low latency.
  • Provides multiple block types for various dataflow operations (e.g., BufferBlock, ActionBlock, TransformBlock).
  • Dataflow blocks support linking to form networks, allowing you to create complex processing topologies.

How to Use

This sample demonstrates a dataflow pipeline that downloads the book "The Iliad of Homer" from a website and searches the text to match individual words with words that reverse the first word's characters.

using System.Net;
using System.Text.RegularExpressions;
using System.Threading.Tasks.Dataflow;

var nonLetterRegex = new Regex(@"\P{L}", RegexOptions.Compiled);
var client = new HttpClient(new HttpClientHandler { AutomaticDecompression = DecompressionMethods.GZip });

// Setup blocks

// Downloads the requested resource as a string.
TransformBlock<string, string> downloadString = new TransformBlock<string, string>(async uri =>
{
    Console.WriteLine("Downloading '{0}'...", uri);

    return await client.GetStringAsync(uri);
});

// Separates the specified text into an array of words.
TransformBlock<string, string[]> createWordList = new TransformBlock<string, string[]>(text =>
{
    Console.WriteLine("Creating word list...");

    // Remove common punctuation by replacing all non-letter characters with a space character.
    text = nonLetterRegex.Replace(text, " ");

    // Separate the text into an array of words.
    return text.Split(new[] { ' ' }, StringSplitOptions.RemoveEmptyEntries);
});

// Removes short words.
TransformBlock<string[], string[]> filterWordList = new TransformBlock<string[], string[]>(words =>
{
    Console.WriteLine("Filtering word list...");

    return words
       .Where(word => word.Length > 3)
       .ToArray();
});

// Finds all words in the specified collection whose reverse also exists in the collection.
TransformManyBlock<string[], string> findReversedWords = new TransformManyBlock<string[], string>(words =>
{
    Console.WriteLine("Finding reversed words...");

    var wordsSet = new HashSet<string>(words);

    return from word in wordsSet
           let reverse = string.Concat(word.Reverse())
           where word != reverse && wordsSet.Contains(reverse)
           select word;
});

// Prints the provided reversed words to the console.
ActionBlock<string> printReversedWords = new ActionBlock<string>(reversedWord =>
{
    Console.WriteLine("Found reversed words {0}/{1}", reversedWord, string.Concat(reversedWord.Reverse()));
});


// Connect the dataflow blocks to form a pipeline.
var linkOptions = new DataflowLinkOptions { PropagateCompletion = true };

downloadString.LinkTo(createWordList, linkOptions);
createWordList.LinkTo(filterWordList, linkOptions);
filterWordList.LinkTo(findReversedWords, linkOptions);
findReversedWords.LinkTo(printReversedWords, linkOptions);

// Post data to the pipeline, "The Iliad of Homer" by Homer.
downloadString.Post("http://www.gutenberg.org/cache/epub/16452/pg16452.txt");

// Mark the head of the pipeline as complete.
downloadString.Complete();

// Wait for the last block in the pipeline to process all messages.
printReversedWords.Completion.Wait();

// Output:
// Downloading 'http://www.gutenberg.org/cache/epub/16452/pg16452.txt'...
// Creating word list...
// Filtering word list...
// Finding reversed words...
// Found reversed words parts/strap
// Found reversed words deer/reed
// Found reversed words deem/meed
// Found reversed words flow/wolf
// ...

More details can be found on Dataflow (Task Parallel Library) and Walkthrough: Creating a Dataflow Pipeline pages.

Main Types

The main types provided by this library are:

  • System.Threading.Tasks.Dataflow.ISourceBlock<TOutput>
  • System.Threading.Tasks.Dataflow.ITargetBlock<TInput>
  • System.Threading.Tasks.Dataflow.IPropagatorBlock<TInput,TOutput>
  • System.Threading.Tasks.Dataflow.ActionBlock<TInput>
  • System.Threading.Tasks.Dataflow.BatchBlock<T>
  • System.Threading.Tasks.Dataflow.BatchedJoinBlock<T1, T2>
  • System.Threading.Tasks.Dataflow.BroadcastBlock<T>
  • System.Threading.Tasks.Dataflow.BufferBlock<T>
  • System.Threading.Tasks.Dataflow.JoinBlock<T1, T2>
  • System.Threading.Tasks.Dataflow.TransformBlock<TInput, TOutput>
  • System.Threading.Tasks.Dataflow.TransformManyBlock<TInput, TOutput>
  • System.Threading.Tasks.Dataflow.WriteOnceBlock<T>

Additional Documentation

Feedback & Contributing

System.Threading.Tasks.Dataflow is released as open source under the MIT license. Bug reports and contributions are welcome at the GitHub repository.

Showing the top 20 packages that depend on System.Threading.Tasks.Dataflow.

Packages Downloads
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. 7b9c946f574dc8c2831a7d1bc29fb7832b4de528 When using NuGet 3.x this package requires at least version 3.4.
7
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. 74b1c703813c8910df5b96f304b0f2b78cdf194d When using NuGet 3.x this package requires at least version 3.4.
7
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. 9013a2af4bec2618af36aab7edbbdd9a52403597 When using NuGet 3.x this package requires at least version 3.4.
7
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. ccea2e606d948094cf861b81e15245833bfb7006 When using NuGet 3.x this package requires at least version 3.4.
7
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. ba3b934aa42697c3faaebfaa1622cdea2f10ff75 When using NuGet 3.x this package requires at least version 3.4.
7
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. 57273284ef6b997ef64890245d4e8940df4d4c6f When using NuGet 3.x this package requires at least version 3.4.
7
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. 1a165a1588309bd8c34f77e1f926e6dbf6ae30d0 When using NuGet 3.x this package requires at least version 3.4.
7
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. bb155063c5d3787c70d8f4de4088c7f0f0ef719c When using NuGet 3.x this package requires at least version 3.4.
7
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. 5f979c18c12f4903b171ca8cefccceeb03b22c32 When using NuGet 3.x this package requires at least version 3.4.
7
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. 7b9e4ef7c114f04a1baf0143fad29c984364a5f5 When using NuGet 3.x this package requires at least version 3.4.
7
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. When using NuGet 3.x this package requires at least version 3.4.
7
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. 23677d3ee7d5160e2d6d420548cf58d74262df10 When using NuGet 3.x this package requires at least version 3.4.
7
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
7
Microsoft.CodeAnalysis.Workspaces.MSBuild
.NET Compiler Platform ("Roslyn") support for analyzing MSBuild projects and solutions. This should be used with at least one of the following packages to add the appropriate language support: - Microsoft.CodeAnalysis.CSharp.Workspaces - Microsoft.CodeAnalysis.VisualBasic.Workspaces More details at https://aka.ms/roslyn-packages This package was built from the source at https://github.com/dotnet/roslyn/commit/2b7d172669b2f7e55803b55f317cfcc2d4279d76.
6
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. When using NuGet 3.x this package requires at least version 3.4.
6
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. 290303f510986f8f832fd2dc9e313cebe06ec68d When using NuGet 3.x this package requires at least version 3.4.
6
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. dcedc87d22ffdc1b86b6a1217dec61c4802ab517 When using NuGet 3.x this package requires at least version 3.4.
6
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. 612cb8b183c52dff0a7f2e57cbfb58e2f18938cc When using NuGet 3.x this package requires at least version 3.4.
6
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. b61e1596d6afb8168ebd9a46d560af4413c6d57f When using NuGet 3.x this package requires at least version 3.4.
6

.NET Framework 4.6.2

  • No dependencies.

.NET 8.0

  • No dependencies.

.NET 9.0

  • No dependencies.

.NET Standard 2.0

  • No dependencies.

.NET Standard 2.1

  • No dependencies.

Version Downloads Last updated
10.0.0-preview.1.25080.5 1 03/12/2025
9.0.9 2 09/19/2025
9.0.8 2 09/19/2025
9.0.7 3 08/01/2025
9.0.6 3 08/01/2025
9.0.5 4 06/05/2025
9.0.4 4 06/05/2025
9.0.3 5 03/12/2025
9.0.2 5 03/12/2025
9.0.1 5 03/12/2025
9.0.0 5 03/12/2025
9.0.0-rc.2.24473.5 1 03/12/2025
9.0.0-rc.1.24431.7 1 03/12/2025
9.0.0-preview.7.24405.7 1 03/12/2025
9.0.0-preview.6.24327.7 1 03/12/2025
9.0.0-preview.5.24306.7 1 03/12/2025
9.0.0-preview.4.24266.19 1 03/12/2025
9.0.0-preview.3.24172.9 1 03/12/2025
9.0.0-preview.2.24128.5 1 03/12/2025
9.0.0-preview.1.24080.9 1 03/12/2025
8.0.1 5 03/12/2025
8.0.0 5 03/12/2025
8.0.0-rc.2.23479.6 1 03/12/2025
8.0.0-rc.1.23419.4 1 03/12/2025
8.0.0-preview.7.23375.6 1 03/12/2025
8.0.0-preview.6.23329.7 1 03/12/2025
8.0.0-preview.5.23280.8 1 03/12/2025
8.0.0-preview.4.23259.5 1 03/12/2025
8.0.0-preview.3.23174.8 1 03/12/2025
8.0.0-preview.2.23128.3 1 03/12/2025
8.0.0-preview.1.23110.8 1 03/12/2025
7.0.0 5 03/12/2025
7.0.0-rc.2.22472.3 1 03/12/2025
7.0.0-rc.1.22426.10 1 03/12/2025
7.0.0-preview.7.22375.6 1 03/12/2025
7.0.0-preview.6.22324.4 1 03/12/2025
7.0.0-preview.5.22301.12 1 03/12/2025
7.0.0-preview.4.22229.4 1 03/12/2025
7.0.0-preview.3.22175.4 1 03/12/2025
7.0.0-preview.2.22152.2 1 03/12/2025
7.0.0-preview.1.22076.8 1 03/12/2025
6.0.0 5 03/12/2025
6.0.0-rc.2.21480.5 1 03/12/2025
6.0.0-rc.1.21451.13 1 03/12/2025
6.0.0-preview.7.21377.19 1 03/12/2025
6.0.0-preview.6.21352.12 1 03/12/2025
6.0.0-preview.5.21301.5 1 03/12/2025
6.0.0-preview.4.21253.7 1 03/12/2025
6.0.0-preview.3.21201.4 1 03/12/2025
6.0.0-preview.2.21154.6 1 03/12/2025
6.0.0-preview.1.21102.12 1 03/12/2025
5.0.0 5 03/12/2025
5.0.0-rc.2.20475.5 1 03/12/2025
5.0.0-rc.1.20451.14 1 03/12/2025
5.0.0-preview.8.20407.11 1 03/12/2025
5.0.0-preview.7.20364.11 1 03/12/2025
5.0.0-preview.6.20305.6 1 03/12/2025
5.0.0-preview.5.20278.1 1 03/12/2025
5.0.0-preview.4.20251.6 1 03/12/2025
5.0.0-preview.3.20214.6 1 03/12/2025
5.0.0-preview.2.20160.6 1 03/12/2025
5.0.0-preview.1.20120.5 1 03/12/2025
4.11.1 1 03/12/2025
4.11.0 1 03/12/2025
4.11.0-preview3.19551.4 1 03/12/2025
4.11.0-preview2.19523.17 1 03/12/2025
4.11.0-preview1.19504.10 1 03/12/2025
4.10.0 1 03/12/2025
4.10.0-rc1.19456.4 1 03/12/2025
4.10.0-preview9.19421.4 1 03/12/2025
4.10.0-preview9.19416.11 1 03/12/2025
4.10.0-preview8.19405.3 1 03/12/2025
4.10.0-preview7.19362.9 1 03/12/2025
4.10.0-preview6.19303.8 1 03/12/2025
4.10.0-preview6.19264.9 1 03/12/2025
4.10.0-preview5.19224.8 1 03/12/2025
4.10.0-preview4.19212.13 1 03/12/2025
4.10.0-preview3.19128.7 1 03/12/2025
4.10.0-preview.19073.11 1 03/12/2025
4.10.0-preview.18571.3 1 03/12/2025
4.9.0 5 03/12/2025
4.9.0-rc1 1 03/12/2025
4.9.0-preview2-26406-04 1 03/12/2025
4.9.0-preview1-26216-02 1 03/12/2025
4.8.0 6 03/12/2025
4.8.0-preview2-25405-01 1 03/12/2025
4.8.0-preview1-25305-02 1 03/12/2025
4.7.0 5 03/12/2025
4.7.0-preview1-24530-04 1 03/12/2025
4.6.0 5 03/12/2025
4.6.0-rc2-24027 1 03/12/2025
4.5.26-beta-23516 1 03/12/2025
4.5.26-beta-23409 1 03/12/2025
4.5.26-beta-23225 1 03/12/2025
4.5.25 1 03/12/2025
4.5.25-beta-23109 1 03/12/2025
4.5.25-beta-23019 1 03/12/2025
4.5.24 1 03/12/2025