System.Threading.Tasks.Dataflow 9.0.0-preview.5.24306.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
Elastic.Apm
Elastic APM .NET Agent base package. This package provides core functionality for transmitting of all Elastic APM types and is a dependent package for all other Elastic APM package. Additionally this package contains the public Agent API that allows you to manually capture transactions and spans. Please install the platform specific package for the best experience. See: https://github.com/elastic/apm-agent-dotnet/tree/master/docs
560
Elastic.Apm
Elastic APM .NET Agent base package. This package provides core functionality for transmitting of all Elastic APM types and is a dependent package for all other Elastic APM package. Additionally this package contains the public Agent API that allows you to manually capture transactions and spans. Please install the platform specific package for the best experience. See: https://github.com/elastic/apm-agent-dotnet/tree/master/docs
93
Elastic.Apm
Elastic APM .NET Agent base package. This package provides core functionality for transmitting of all Elastic APM types and is a dependent package for all other Elastic APM package. Additionally this package contains the public Agent API that allows you to manually capture transactions and spans. Please install the platform specific package for the best experience. See: https://github.com/elastic/apm-agent-dotnet/tree/master/docs
65
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. 6985b9f6844d51ba1197c3f52aabc7291bb15bc1 When using NuGet 3.x this package requires at least version 3.4.
46
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.
40
Elastic.Apm
Elastic APM .NET Agent base package. This package provides core functionality for transmitting of all Elastic APM types and is a dependent package for all other Elastic APM package. Additionally this package contains the public Agent API that allows you to manually capture transactions and spans. Please install the platform specific package for the best experience. See: https://github.com/elastic/apm-agent-dotnet/tree/main/docs
36
Marten
.NET Transactional Document DB and Event Store on PostgreSQL
36
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.
35
Marten
Postgresql as a Document Db and Event Store for .Net Development
35
Marten
Postgresql as a Document Db and Event Store for .Net Development
33
Microsoft.NETCore.App
A set of .NET API's that are included in the default .NET Core application model. caa7b7e2bad98e56a687fb5cbaf60825500800f7 When using NuGet 3.x this package requires at least version 3.4.
32
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.
27
Marten
Postgresql as a Document Db and Event Store for .Net Development
26
Microsoft.Build
This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.
22
Marten
.NET Transactional Document DB and Event Store on PostgreSQL
21
Marten
.NET Transactional Document DB and Event Store on PostgreSQL
20
Elastic.Apm
Elastic APM .NET Agent base package. This package provides core functionality for transmitting of all Elastic APM types and is a dependent package for all other Elastic APM package. Additionally this package contains the public Agent API that allows you to manually capture transactions and spans. Please install the platform specific package for the best experience. See: https://github.com/elastic/apm-agent-dotnet/tree/main/docs
19

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 Standard 2.0

  • No dependencies.

.NET Standard 2.1

  • No dependencies.

Version Downloads Last updated
9.0.0 2 11/18/2024
9.0.0-rc.2.24473.5 4 10/09/2024
9.0.0-rc.1.24431.7 5 09/18/2024
9.0.0-preview.7.24405.7 8 08/21/2024
9.0.0-preview.6.24327.7 4 07/13/2024
9.0.0-preview.5.24306.7 7 06/28/2024
9.0.0-preview.4.24266.19 6 05/24/2024
9.0.0-preview.3.24172.9 5 04/14/2024
9.0.0-preview.2.24128.5 4 03/19/2024
9.0.0-preview.1.24080.9 8 04/17/2024
8.0.1 6 07/12/2024
8.0.0 16 12/18/2023
8.0.0-rc.2.23479.6 16 11/12/2023
8.0.0-rc.1.23419.4 23 10/17/2023
8.0.0-preview.7.23375.6 19 08/18/2023
8.0.0-preview.6.23329.7 20 11/06/2023
8.0.0-preview.5.23280.8 13 08/21/2023
8.0.0-preview.4.23259.5 13 05/18/2023
8.0.0-preview.3.23174.8 20 06/01/2023
8.0.0-preview.2.23128.3 27 04/14/2023
8.0.0-preview.1.23110.8 9 04/09/2023
7.0.0 53 04/08/2023
7.0.0-rc.2.22472.3 52 04/01/2023
7.0.0-rc.1.22426.10 50 04/03/2023
7.0.0-preview.7.22375.6 36 04/02/2023
7.0.0-preview.6.22324.4 32 04/13/2023
7.0.0-preview.5.22301.12 27 03/29/2023
7.0.0-preview.4.22229.4 16 04/04/2023
7.0.0-preview.3.22175.4 38 04/03/2023
7.0.0-preview.2.22152.2 38 04/07/2023
7.0.0-preview.1.22076.8 30 08/16/2023
6.0.2-mauipre.1.22102.15 30 04/08/2023
6.0.2-mauipre.1.22054.8 35 04/21/2023
6.0.0 36 04/08/2023
6.0.0-rc.2.21480.5 34 04/10/2023
6.0.0-rc.1.21451.13 27 08/11/2023
6.0.0-preview.7.21377.19 27 04/06/2023
6.0.0-preview.6.21352.12 40 04/03/2023
6.0.0-preview.5.21301.5 14 04/01/2023
6.0.0-preview.4.21253.7 27 04/10/2023
6.0.0-preview.3.21201.4 43 04/05/2023
6.0.0-preview.2.21154.6 33 04/03/2023
6.0.0-preview.1.21102.12 26 04/02/2023
5.0.0 43 01/17/2021
5.0.0-rc.2.20475.5 21 04/11/2023
5.0.0-rc.1.20451.14 37 04/01/2023
5.0.0-preview.8.20407.11 25 04/05/2023
5.0.0-preview.7.20364.11 32 04/30/2023
5.0.0-preview.6.20305.6 26 04/07/2023
5.0.0-preview.5.20278.1 27 04/18/2023
5.0.0-preview.4.20251.6 45 04/07/2023
5.0.0-preview.3.20214.6 43 04/06/2023
5.0.0-preview.2.20160.6 8 06/27/2024
5.0.0-preview.1.20120.5 31 04/13/2023
4.11.1 45 09/16/2021
4.11.0 39 05/05/2023
4.11.0-preview3.19551.4 22 07/16/2023
4.11.0-preview2.19523.17 22 04/24/2023
4.11.0-preview1.19504.10 54 04/06/2023
4.10.0 32 07/22/2023
4.10.0-rc1.19456.4 25 05/04/2023
4.10.0-preview9.19421.4 52 04/14/2023
4.10.0-preview9.19416.11 55 04/14/2023
4.10.0-preview8.19405.3 27 04/06/2023
4.10.0-preview7.19362.9 38 03/31/2023
4.10.0-preview6.19303.8 37 04/11/2023
4.10.0-preview6.19264.9 26 04/02/2023
4.10.0-preview5.19224.8 28 04/08/2023
4.10.0-preview4.19212.13 42 04/03/2023
4.10.0-preview3.19128.7 19 04/30/2023
4.10.0-preview.19073.11 36 04/06/2023
4.10.0-preview.18571.3 28 04/13/2023
4.9.0 616 11/21/2019
4.9.0-rc1 21 04/08/2023
4.9.0-preview2-26406-04 15 08/29/2023
4.9.0-preview1-26216-02 42 03/28/2023
4.8.0 36 03/20/2023
4.8.0-preview2-25405-01 30 04/01/2023
4.8.0-preview1-25305-02 44 04/26/2023
4.7.0 30 06/30/2020
4.7.0-preview1-24530-04 39 04/06/2023
4.6.0 71 11/26/2019
4.6.0-rc2-24027 47 04/07/2023
4.5.26-beta-23516 53 04/01/2023
4.5.26-beta-23409 23 07/12/2023
4.5.26-beta-23225 37 04/08/2023
4.5.25 40 04/10/2023
4.5.25-beta-23109 14 04/04/2023
4.5.25-beta-23019 33 04/11/2023
4.5.24 33 04/08/2023