System.Threading.Tasks.Dataflow 9.0.10
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 | 155 | 
| Microsoft.Build This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects. | 128 | 
| R4Mvc.Tools R4Mvc is a tool that generates strongly typed helpers for ASP.NET Core MVC. | 113 | 
| Microsoft.Build This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects. | 112 | 
| Microsoft.Build.Tasks.Core This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild. | 111 | 
| Microsoft.Build This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects. | 109 | 
| Microsoft.Build.Tasks.Core This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild. | 108 | 
| Microsoft.Build This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects. | 108 | 
| Microsoft.AspNetCore.NodeServices Invoke Node.js modules at runtime in ASP.NET Core applications. | 108 | 
| Microsoft.Build This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects. | 107 | 
| Microsoft.Build This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects. | 105 | 
| Microsoft.Build.Tasks.Core This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild. | 104 | 
| Microsoft.Build This package contains the Microsoft.Build assembly which is used to create, edit, and evaluation MSBuild projects. | 104 | 
| Microsoft.Build This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects. | 103 | 
| Microsoft.Build This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects. | 102 | 
| Microsoft.Build This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects. | 101 | 
| Microsoft.Build.Tasks.Core This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild. | 101 | 
.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.