AsyncEnumerator 2.1.0

Introduces IAsyncEnumerable, IAsyncEnumerator, ForEachAsync(), and ParallelForEachAsync()
GitHub: https://github.com/tyrotoxin/AsyncEnumerable

PROBLEM SPACE

Helps to (a) create an element provider, where producing an element can take a lot of time
due to dependency on other asynchronous events (e.g. wait handles, network streams), and
(b) a consumer that processes those element as soon as they are ready without blocking
the thread (the processing is scheduled on a worker thread instead).


EXAMPLE

using System.Collections.Async;

static IAsyncEnumerable<int> ProduceAsyncNumbers(int start, int end)
{
 return new AsyncEnumerable<int>(async yield => {

   // Just to show that ReturnAsync can be used multiple times
   await yield.ReturnAsync(start);

   for (int number = start + 1; number <= end; number++)
     await yield.ReturnAsync(number);

   // You can break the enumeration loop with the following call:
   yield.Break();

   // This won't be executed due to the loop break above
   await yield.ReturnAsync(12345);
 });
}

// Just to compare with synchronous version of enumerator
static IEnumerable<int> ProduceNumbers(int start, int end)
{
 yield return start;

 for (int number = start + 1; number <= end; number++)
   yield return number;

 yield break;

 yield return 12345;
}

static async Task ConsumeNumbersAsync()
{
 var asyncEnumerableCollection = ProduceAsyncNumbers(start: 1, end: 10);
 await asyncEnumerableCollection.ForEachAsync(async number => {
   await Console.Out.WriteLineAsync($"{number}");
 });
}

// Just to compare with synchronous version of enumeration
static void ConsumeNumbers()
{
 var enumerableCollection = ProduceNumbers(start: 1, end: 10);
 foreach (var number in enumerableCollection) {
   Console.Out.WriteLine($"{number}");
 }
}

There is a newer version of this package available.
See the version list below for details.
Install-Package AsyncEnumerator -Version 2.1.0
dotnet add package AsyncEnumerator --version 2.1.0
<PackageReference Include="AsyncEnumerator" Version="2.1.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add AsyncEnumerator --version 2.1.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.

Release Notes

2.1.0: New extension methods: Batch, UnionAll, Single, SingleOrDefault, DefaultIfEmpty, Cast.
2.0.0: Revise design of the library: same features, but slight paradigm shift and interface breaking changes.
1.5.0: Add support for .NET Standard, minor improvements.
1.4.2: Add finalizer to AsyncEnumerator and call Dispose in ForEachAsync and ParallelForEachAsync extension methods.
1.4.0: Add new generic type AsyncEnumeratorWithState for performance optimization.
      Now IAsyncEnumerator<T> is covariant.
      Add ForEachAsync, ParallelForeachAsync, and LINQ-style extension methods for IAsyncEnumerator.
1.2.1: New Linq-style extension methods in System.Collections.Async namespace.
1.1.0: Add ParallelForEachAsync extension methods for IEnumerable<T> and IAsyncEnumerable<T> in System.Collections.Async namespace.

Dependencies

This package has no dependencies.

Showing the top 3 GitHub repositories that depend on AsyncEnumerator:

Repository Stars
RevoLand/Steam-Library-Manager
Open source utility to manage Steam, Origin and Uplay libraries in ease of use with multi library support
planetarium/libplanet
Blockchain core in C#/.NET for persistent peer-to-peer online games
Dasync/Dasync
Every developer deserves the right of creating microservices without using any framework 🤍

Read more about the GitHub Usage information on our documentation.

Version History

Version Downloads Last updated
4.0.2 12,478 12/4/2019
4.0.1 27,365 10/22/2019
4.0.0 3,157 10/18/2019
3.1.0 16,919 9/23/2019
2.2.2 410,275 1/27/2019
2.2.1 707,236 5/29/2018
2.2.0 16,786 5/18/2018
2.1.1 89,399 1/20/2018
2.1.0 170,066 5/22/2017
2.0.1 44,371 2/13/2017
1.5.0 3,124 2/12/2017
1.4.2 1,064 2/6/2017
1.3.0 1,335 1/20/2017
1.2.3 6,388 1/6/2017
1.2.2 1,401 12/11/2016
1.2.1 413 12/10/2016
1.2.0 15,626 11/29/2016
1.1.3 443 11/28/2016
1.1.2 18,024 8/29/2016
1.0.3 2,129 4/28/2016
Show less