System.Threading.Tasks.Dataflow 9.0.0-preview.4.24266.19

The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org. Prefix Reserved
This is a prerelease version of System.Threading.Tasks.Dataflow.
There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package System.Threading.Tasks.Dataflow --version 9.0.0-preview.4.24266.19
NuGet\Install-Package System.Threading.Tasks.Dataflow -Version 9.0.0-preview.4.24266.19
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="System.Threading.Tasks.Dataflow" Version="9.0.0-preview.4.24266.19" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add System.Threading.Tasks.Dataflow --version 9.0.0-preview.4.24266.19
#r "nuget: System.Threading.Tasks.Dataflow, 9.0.0-preview.4.24266.19"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install System.Threading.Tasks.Dataflow as a Cake Addin
#addin nuget:?package=System.Threading.Tasks.Dataflow&version=9.0.0-preview.4.24266.19&prerelease

// Install System.Threading.Tasks.Dataflow as a Cake Tool
#tool nuget:?package=System.Threading.Tasks.Dataflow&version=9.0.0-preview.4.24266.19&prerelease

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.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 is compatible. 
.NET Framework net461 was computed.  net462 is compatible.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • .NETFramework 4.6.2

    • No dependencies.
  • .NETStandard 2.0

    • No dependencies.
  • .NETStandard 2.1

    • No dependencies.
  • net8.0

    • No dependencies.
  • net9.0

    • No dependencies.

NuGet packages (504)

Showing the top 5 NuGet packages that depend on System.Threading.Tasks.Dataflow:

Package Downloads
Microsoft.Azure.WebJobs The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org.

This package contains the runtime assemblies for Microsoft.Azure.WebJobs.Host. It also adds rich diagnostics capabilities which makes it easier to monitor the WebJobs in the dashboard. For more information, please visit http://go.microsoft.com/fwlink/?LinkID=320971

Microsoft.Build The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org.

This package contains the Microsoft.Build assembly which is used to create, edit, and evaluate MSBuild projects.

Microsoft.Build.Tasks.Core The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org.

This package contains the Microsoft.Build.Tasks assembly which implements the commonly used tasks of MSBuild.

Microsoft.Build.Runtime The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org.

This package delivers a complete executable copy of MSBuild. Reference this package only if your application needs to load projects or execute in-process builds without requiring installation of MSBuild. Successfully evaluating projects using this package requires aggregating additional components (like the compilers) into an application directory.

Microsoft.CodeAnalysis.Workspaces.MSBuild The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org.

.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.

GitHub repositories (117)

Showing the top 5 popular GitHub repositories that depend on System.Threading.Tasks.Dataflow:

Repository Stars
files-community/Files
Building the best file manager for Windows
jellyfin/jellyfin
The Free Software Media System
dotnet/roslyn
The Roslyn .NET compiler provides C# and Visual Basic languages with rich code analysis APIs.
stride3d/stride
Stride Game Engine (formerly Xenko)
dotnet/msbuild
The Microsoft Build Engine (MSBuild) is the build platform for .NET and Visual Studio.
Version Downloads Last updated
9.0.0-preview.5.24306.7 89 6/11/2024
9.0.0-preview.4.24266.19 411 5/21/2024
9.0.0-preview.3.24172.9 882 4/11/2024
9.0.0-preview.2.24128.5 765 3/12/2024
9.0.0-preview.1.24080.9 8,061 2/13/2024
8.0.0 1,904,254 11/14/2023
8.0.0-rc.2.23479.6 8,605 10/10/2023
8.0.0-rc.1.23419.4 2,802 9/12/2023
8.0.0-preview.7.23375.6 2,243 8/8/2023
8.0.0-preview.6.23329.7 1,471 7/11/2023
8.0.0-preview.5.23280.8 1,394 6/13/2023
8.0.0-preview.4.23259.5 1,580 5/16/2023
8.0.0-preview.3.23174.8 2,560 4/11/2023
8.0.0-preview.2.23128.3 1,278 3/14/2023
8.0.0-preview.1.23110.8 3,537 2/21/2023
7.0.0 10,298,719 11/7/2022
7.0.0-rc.2.22472.3 12,875 10/11/2022
7.0.0-rc.1.22426.10 785 9/14/2022
7.0.0-preview.7.22375.6 17,504 8/9/2022
7.0.0-preview.6.22324.4 4,214 7/12/2022
7.0.0-preview.5.22301.12 1,241 6/14/2022
7.0.0-preview.4.22229.4 949 5/10/2022
7.0.0-preview.3.22175.4 569 4/13/2022
7.0.0-preview.2.22152.2 883 3/14/2022
7.0.0-preview.1.22076.8 732 2/17/2022
6.0.2-mauipre.1.22102.15 1,225 2/15/2022
6.0.2-mauipre.1.22054.8 3,992 1/19/2022
6.0.0 34,874,982 11/8/2021
6.0.0-rc.2.21480.5 3,819 10/12/2021
6.0.0-rc.1.21451.13 1,805 9/14/2021
6.0.0-preview.7.21377.19 2,136 8/10/2021
6.0.0-preview.6.21352.12 1,014 7/14/2021
6.0.0-preview.5.21301.5 1,682 6/15/2021
6.0.0-preview.4.21253.7 8,917 5/24/2021
6.0.0-preview.3.21201.4 1,938 4/8/2021
6.0.0-preview.2.21154.6 1,054 3/11/2021
6.0.0-preview.1.21102.12 9,303 2/12/2021
5.0.0 17,599,886 11/9/2020
5.0.0-rc.2.20475.5 5,629 10/13/2020
5.0.0-rc.1.20451.14 196,168 9/14/2020
5.0.0-preview.8.20407.11 1,046 8/25/2020
5.0.0-preview.7.20364.11 1,069 7/21/2020
5.0.0-preview.6.20305.6 1,390 6/25/2020
5.0.0-preview.5.20278.1 3,927 6/10/2020
5.0.0-preview.4.20251.6 2,099 5/18/2020
5.0.0-preview.3.20214.6 1,243 4/23/2020
5.0.0-preview.2.20160.6 1,423 4/2/2020
5.0.0-preview.1.20120.5 1,045 3/16/2020
4.11.1 14,078,929 5/12/2020
4.11.0 6,542,390 12/3/2019
4.11.0-preview3.19551.4 1,704 11/13/2019
4.11.0-preview2.19523.17 4,854 11/1/2019
4.11.0-preview1.19504.10 1,253 10/15/2019
4.10.0 5,433,515 9/23/2019
4.10.0-rc1.19456.4 1,523 9/16/2019
4.10.0-preview9.19421.4 1,797 9/4/2019
4.10.0-preview9.19416.11 634 9/4/2019
4.10.0-preview8.19405.3 6,152 8/13/2019
4.10.0-preview7.19362.9 3,917 7/23/2019
4.10.0-preview6.19303.8 2,883 6/12/2019
4.10.0-preview6.19264.9 641 9/4/2019
4.10.0-preview5.19224.8 11,633 5/6/2019
4.10.0-preview4.19212.13 1,404 4/18/2019
4.10.0-preview3.19128.7 1,637 3/6/2019
4.10.0-preview.19073.11 5,496 1/29/2019
4.10.0-preview.18571.3 21,988 12/3/2018
4.9.0 85,682,600 5/29/2018
4.9.0-rc1 8,320 5/6/2018
4.9.0-preview2-26406-04 4,617 4/10/2018
4.9.0-preview1-26216-02 10,792 2/26/2018
4.8.0 114,434,716 8/11/2017
4.8.0-preview2-25405-01 13,832 6/27/2017
4.8.0-preview1-25305-02 4,081 5/9/2017
4.7.0 43,576,781 11/15/2016
4.7.0-preview1-24530-04 48,446 10/24/2016
4.6.0 131,731,866 6/27/2016
4.6.0-rc2-24027 2,238,254 5/16/2016
4.5.26-beta-23516 19,741 11/18/2015
4.5.26-beta-23409 3,154 10/15/2015
4.5.26-beta-23225 124,209 9/2/2015
4.5.25 1,970,383 7/29/2015
4.5.25-beta-23109 2,951 7/27/2015
4.5.25-beta-23019 3,113 6/30/2015
4.5.24 4,129,918 2/28/2017