System.Threading.Tasks.Dataflow 11.0.0-preview.4.26230.115

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
Provides a set of packages that can be used when building portable libraries on .NETCore based platforms. \r\n TFS ID: 1599443, GitHub SHA: https://github.com/dotnet/corefx/tree/eede273a4dfabcea608621f5e1bbf8ad00584cfb
211
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.
175
Microsoft.Build.Tasks.Core
This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild.
173
Microsoft.Build.Tasks.Core
This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild.
166
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
165
Microsoft.Build.Tasks.Core
This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild.
163
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
159
R4Mvc.Tools
R4Mvc is a tool that generates strongly typed helpers for ASP.NET Core MVC.
159
Microsoft.Build.Tasks.Core
This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild.
158
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
157
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
156
Microsoft.Build.Tasks.Core
This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild.
156
Microsoft.Build.Tasks.Core
This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild.
155
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
154
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
153
Microsoft.AspNetCore.NodeServices
Invoke Node.js modules at runtime in ASP.NET Core applications.
153
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluation MSBuild projects.
152
Microsoft.Build.Tasks.Core
This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild.
152

.NET 10.0

  • No dependencies.

.NET 11.0

  • No dependencies.

.NET Framework 4.6.2

  • No dependencies.

.NET Standard 2.0

  • No dependencies.

.NET Standard 2.1

  • No dependencies.

Version Downloads Last updated
11.0.0-preview.4.26230.115 8 5/12/2026
11.0.0-preview.3.26207.106 9 5/3/2026
11.0.0-preview.2.26159.112 15 3/11/2026
11.0.0-preview.1.26104.118 14 2/13/2026
10.0.8 6 5/12/2026
10.0.7 9 5/3/2026
10.0.6 11 5/3/2026
10.0.5 15 3/17/2026
10.0.4 17 3/11/2026
10.0.3 18 2/13/2026
10.0.2 21 1/15/2026
10.0.1 31 12/12/2025
10.0.0 41 11/12/2025
10.0.0-rc.2.25502.107 54 10/21/2025
10.0.0-rc.1.25451.107 55 9/16/2025
10.0.0-preview.7.25380.108 60 8/15/2025
10.0.0-preview.6.25358.103 86 7/16/2025
10.0.0-preview.5.25277.114 74 6/9/2025
10.0.0-preview.4.25258.110 64 5/16/2025
10.0.0-preview.3.25171.5 75 4/11/2025
10.0.0-preview.2.25163.2 63 3/21/2025
10.0.0-preview.1.25080.5 75 2/27/2025
9.0.16 6 5/12/2026
9.0.15 10 5/3/2026
9.0.14 17 3/11/2026
9.0.13 17 2/13/2026
9.0.12 20 1/15/2026
9.0.11 38 11/12/2025
9.0.10 48 10/21/2025
9.0.9 57 9/17/2025
9.0.8 59 8/5/2025
9.0.7 58 7/11/2025
9.0.6 69 6/13/2025
9.0.5 75 5/17/2025
9.0.4 81 4/9/2025
9.0.3 90 3/16/2025
9.0.2 85 2/22/2025
9.0.1 88 1/18/2025
9.0.0 85 11/18/2024
9.0.0-rc.2.24473.5 94 10/25/2024
9.0.0-rc.1.24431.7 93 9/12/2024
9.0.0-preview.7.24405.7 102 8/15/2024
9.0.0-preview.6.24327.7 99 7/11/2024
9.0.0-preview.5.24306.7 88 6/14/2024
9.0.0-preview.4.24266.19 90 6/5/2024
9.0.0-preview.3.24172.9 94 4/17/2024
9.0.0-preview.2.24128.5 104 3/28/2024
9.0.0-preview.1.24080.9 101 2/26/2024
8.0.1 82 7/9/2024
8.0.0 93 11/16/2023
8.0.0-rc.2.23479.6 98 10/13/2023
8.0.0-rc.1.23419.4 108 9/15/2023
8.0.0-preview.7.23375.6 113 8/23/2023
8.0.0-preview.6.23329.7 102 8/1/2023
8.0.0-preview.5.23280.8 112 7/14/2023
8.0.0-preview.4.23259.5 107 8/1/2023
8.0.0-preview.3.23174.8 97 5/15/2023
8.0.0-preview.2.23128.3 107 3/20/2023
8.0.0-preview.1.23110.8 104 2/23/2023
7.0.0 104 12/4/2022
7.0.0-rc.2.22472.3 104 11/22/2022
7.0.0-rc.1.22426.10 106 9/15/2022
7.0.0-preview.7.22375.6 100 9/11/2022
7.0.0-preview.6.22324.4 103 9/15/2022
7.0.0-preview.5.22301.12 103 6/28/2022
7.0.0-preview.4.22229.4 103 6/28/2022
7.0.0-preview.3.22175.4 101 6/28/2022
7.0.0-preview.2.22152.2 111 6/28/2022
7.0.0-preview.1.22076.8 105 6/28/2022
6.0.2-mauipre.1.22102.15 99 6/28/2022
6.0.2-mauipre.1.22054.8 111 6/28/2022
6.0.0 124 6/28/2022
6.0.0-rc.2.21480.5 116 6/28/2022
6.0.0-rc.1.21451.13 112 6/28/2022
6.0.0-preview.7.21377.19 120 6/28/2022
6.0.0-preview.6.21352.12 97 6/28/2022
6.0.0-preview.5.21301.5 107 6/28/2022
6.0.0-preview.4.21253.7 106 6/28/2022
6.0.0-preview.3.21201.4 118 6/28/2022
6.0.0-preview.2.21154.6 107 6/28/2022
6.0.0-preview.1.21102.12 109 6/28/2022
5.0.0 101 6/28/2022
5.0.0-rc.2.20475.5 109 6/28/2022
5.0.0-rc.1.20451.14 96 6/28/2022
5.0.0-preview.8.20407.11 128 6/28/2022
5.0.0-preview.7.20364.11 111 6/28/2022
5.0.0-preview.6.20305.6 112 6/28/2022
5.0.0-preview.5.20278.1 120 6/28/2022
5.0.0-preview.4.20251.6 105 6/28/2022
5.0.0-preview.3.20214.6 130 6/28/2022
5.0.0-preview.2.20160.6 99 6/28/2022
5.0.0-preview.1.20120.5 106 6/28/2022
4.11.1 108 6/28/2022
4.11.0 108 6/28/2022
4.11.0-preview3.19551.4 102 6/28/2022
4.11.0-preview2.19523.17 127 6/28/2022
4.11.0-preview1.19504.10 105 6/28/2022
4.10.0 104 6/28/2022
4.10.0-rc1.19456.4 105 6/28/2022
4.10.0-preview9.19421.4 114 6/28/2022
4.10.0-preview9.19416.11 112 6/28/2022
4.10.0-preview8.19405.3 108 6/28/2022
4.10.0-preview7.19362.9 110 6/28/2022
4.10.0-preview6.19303.8 109 6/28/2022
4.10.0-preview6.19264.9 123 6/28/2022
4.10.0-preview5.19224.8 109 6/28/2022
4.10.0-preview4.19212.13 112 6/28/2022
4.10.0-preview3.19128.7 103 6/28/2022
4.10.0-preview.19073.11 114 6/28/2022
4.10.0-preview.18571.3 104 6/28/2022
4.9.0 110 6/28/2022
4.9.0-rc1 98 6/28/2022
4.9.0-preview2-26406-04 102 6/28/2022
4.9.0-preview1-26216-02 101 6/28/2022
4.8.0 106 6/28/2022
4.8.0-preview2-25405-01 103 6/28/2022
4.8.0-preview1-25305-02 114 6/28/2022
4.7.0 106 6/28/2022
4.7.0-preview1-24530-04 110 6/28/2022
4.6.0 108 6/28/2022
4.6.0-rc2-24027 97 6/28/2022
4.5.26-beta-23516 111 6/28/2022
4.5.26-beta-23409 100 6/28/2022
4.5.26-beta-23225 106 6/28/2022
4.5.25 94 6/28/2022
4.5.25-beta-23109 101 6/28/2022
4.5.25-beta-23019 100 6/28/2022
4.5.24 101 6/28/2022