System.Threading.Tasks.Dataflow 10.0.9

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.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
170
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
171
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
177
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
185
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
193
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
197
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
203
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
225
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluation MSBuild projects.
171
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluation MSBuild projects.
179
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluation MSBuild projects.
180
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluation MSBuild projects.
181
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluation MSBuild projects.
182
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluation MSBuild projects.
192
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluation MSBuild projects.
194
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluation MSBuild projects.
196
Microsoft.Build.Tasks.Core
This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild.
188
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/8edf7bcd4f1594c3d68a6a567469f41dbd33dd1b.
174
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/fa72fa61b0d822ea8a3fbeb96f668340419ab5cd.
171

https://go.microsoft.com/fwlink/?LinkID=799421

.NET Framework 4.6.2

  • No dependencies.

.NET 8.0

  • No dependencies.

.NET 9.0

  • No dependencies.

.NET 10.0

  • No dependencies.

.NET Standard 2.0

  • No dependencies.

.NET Standard 2.1

  • No dependencies.

Version Downloads Last updated
11.0.0-preview.5.26302.115 9 06/09/2026
11.0.0-preview.4.26230.115 11 05/12/2026
11.0.0-preview.3.26207.106 20 04/14/2026
11.0.0-preview.2.26159.112 25 03/12/2026
11.0.0-preview.1.26104.118 27 02/11/2026
10.0.9 7 06/09/2026
10.0.8 9 05/12/2026
10.0.7 20 04/21/2026
10.0.6 27 04/14/2026
10.0.5 30 03/13/2026
10.0.4 30 03/12/2026
10.0.3 35 02/11/2026
10.0.2 29 01/13/2026
10.0.1 48 12/10/2025
10.0.0 71 11/12/2025
10.0.0-rc.2.25502.107 83 10/15/2025
10.0.0-rc.1.25451.107 88 09/10/2025
10.0.0-preview.7.25380.108 80 08/12/2025
10.0.0-preview.6.25358.103 101 07/16/2025
10.0.0-preview.5.25277.114 87 06/07/2025
10.0.0-preview.4.25258.110 93 05/15/2025
10.0.0-preview.3.25171.5 96 04/12/2025
10.0.0-preview.2.25163.2 132 04/03/2025
10.0.0-preview.1.25080.5 91 04/02/2025
9.0.17 9 06/09/2026
9.0.16 13 05/13/2026
9.0.15 21 04/14/2026
9.0.14 33 03/12/2026
9.0.13 31 02/11/2026
9.0.12 35 01/13/2026
9.0.11 71 11/12/2025
9.0.10 63 10/15/2025
9.0.9 80 09/10/2025
9.0.8 86 08/05/2025
9.0.7 92 07/09/2025
9.0.6 99 06/11/2025
9.0.5 94 05/15/2025
9.0.4 103 04/10/2025
9.0.3 117 03/30/2025
9.0.2 104 03/30/2025
9.0.1 103 03/30/2025
9.0.0 108 11/14/2024
9.0.0-rc.2.24473.5 110 10/18/2024
9.0.0-rc.1.24431.7 101 10/17/2024
9.0.0-preview.7.24405.7 100 08/20/2024
9.0.0-preview.6.24327.7 137 07/19/2024
9.0.0-preview.5.24306.7 147 07/19/2024
9.0.0-preview.4.24266.19 118 07/19/2024
9.0.0-preview.3.24172.9 122 07/19/2024
9.0.0-preview.2.24128.5 130 07/19/2024
9.0.0-preview.1.24080.9 122 07/19/2024
8.0.1 139 07/19/2024
8.0.0 173 07/19/2024
8.0.0-rc.2.23479.6 129 07/19/2024
8.0.0-rc.1.23419.4 125 07/19/2024
8.0.0-preview.7.23375.6 125 07/19/2024
8.0.0-preview.6.23329.7 129 07/19/2024
8.0.0-preview.5.23280.8 123 07/19/2024
8.0.0-preview.4.23259.5 130 07/19/2024
8.0.0-preview.3.23174.8 137 07/19/2024
8.0.0-preview.2.23128.3 126 07/19/2024
8.0.0-preview.1.23110.8 139 07/19/2024
7.0.0 157 02/09/2024
7.0.0-rc.2.22472.3 116 07/19/2024
7.0.0-rc.1.22426.10 113 07/19/2024
7.0.0-preview.7.22375.6 127 07/19/2024
7.0.0-preview.6.22324.4 136 07/19/2024
7.0.0-preview.5.22301.12 120 07/19/2024
7.0.0-preview.4.22229.4 135 07/19/2024
7.0.0-preview.3.22175.4 108 07/19/2024
7.0.0-preview.2.22152.2 118 07/19/2024
7.0.0-preview.1.22076.8 149 07/19/2024
6.0.2-mauipre.1.22102.15 105 10/20/2024
6.0.2-mauipre.1.22054.8 105 01/13/2025
6.0.0 146 02/04/2024
6.0.0-rc.2.21480.5 130 07/19/2024
6.0.0-rc.1.21451.13 133 07/19/2024
6.0.0-preview.7.21377.19 125 07/19/2024
6.0.0-preview.6.21352.12 121 07/19/2024
6.0.0-preview.5.21301.5 121 07/19/2024
6.0.0-preview.4.21253.7 118 07/19/2024
6.0.0-preview.3.21201.4 125 07/19/2024
6.0.0-preview.2.21154.6 116 07/19/2024
6.0.0-preview.1.21102.12 126 07/19/2024
5.0.0 130 07/19/2024
5.0.0-rc.2.20475.5 127 07/19/2024
5.0.0-rc.1.20451.14 128 07/19/2024
5.0.0-preview.8.20407.11 138 07/19/2024
5.0.0-preview.7.20364.11 120 07/19/2024
5.0.0-preview.6.20305.6 138 07/19/2024
5.0.0-preview.5.20278.1 121 07/19/2024
5.0.0-preview.4.20251.6 131 07/19/2024
5.0.0-preview.3.20214.6 133 07/19/2024
5.0.0-preview.2.20160.6 131 07/19/2024
5.0.0-preview.1.20120.5 117 07/19/2024
4.11.1 144 07/19/2024
4.11.0 128 07/19/2024
4.11.0-preview3.19551.4 125 07/19/2024
4.11.0-preview2.19523.17 139 07/19/2024
4.11.0-preview1.19504.10 120 07/19/2024
4.10.0 127 07/19/2024
4.10.0-rc1.19456.4 135 07/19/2024
4.10.0-preview9.19421.4 130 07/19/2024
4.10.0-preview9.19416.11 130 07/19/2024
4.10.0-preview8.19405.3 130 07/19/2024
4.10.0-preview7.19362.9 136 07/19/2024
4.10.0-preview6.19303.8 122 07/19/2024
4.10.0-preview6.19264.9 129 07/19/2024
4.10.0-preview5.19224.8 132 07/19/2024
4.10.0-preview4.19212.13 125 07/19/2024
4.10.0-preview3.19128.7 133 07/19/2024
4.10.0-preview.19073.11 130 07/19/2024
4.10.0-preview.18571.3 122 07/19/2024
4.9.0 148 02/04/2024
4.9.0-rc1 124 07/19/2024
4.9.0-preview2-26406-04 129 07/19/2024
4.9.0-preview1-26216-02 126 07/19/2024
4.8.0 138 07/19/2024
4.8.0-preview2-25405-01 131 07/19/2024
4.8.0-preview1-25305-02 135 07/19/2024
4.7.0 137 07/19/2024
4.7.0-preview1-24530-04 122 07/19/2024
4.6.0 148 07/19/2024
4.6.0-rc2-24027 134 07/19/2024
4.5.26-beta-23516 140 07/19/2024
4.5.26-beta-23409 149 07/19/2024
4.5.26-beta-23225 136 07/19/2024
4.5.25 133 07/19/2024
4.5.25-beta-23109 135 07/19/2024
4.5.25-beta-23019 121 07/19/2024
4.5.24 119 07/19/2024