Temppus.BatchedAsyncEnumerable
1.0.1
See the version list below for details.
dotnet add package Temppus.BatchedAsyncEnumerable --version 1.0.1
NuGet\Install-Package Temppus.BatchedAsyncEnumerable -Version 1.0.1
<PackageReference Include="Temppus.BatchedAsyncEnumerable" Version="1.0.1" />
paket add Temppus.BatchedAsyncEnumerable --version 1.0.1
#r "nuget: Temppus.BatchedAsyncEnumerable, 1.0.1"
// Install Temppus.BatchedAsyncEnumerable as a Cake Addin #addin nuget:?package=Temppus.BatchedAsyncEnumerable&version=1.0.1 // Install Temppus.BatchedAsyncEnumerable as a Cake Tool #tool nuget:?package=Temppus.BatchedAsyncEnumerable&version=1.0.1
BatchedAsyncEnumerable
Extension method that will transform IAsyncEnumerable<T>
to IAsyncEnumerable<T[]>
allowing for efficient asynchronous batch processing with one line of code.
Nuget available here.
Motivation:
The IAsyncEnumerable<T>
type is powerful, but using it comes with many pitfalls. Creating a batching method for this type revealed more gotchas than expected, given the nature of the async
and yield
combination. These issues are extremely hard to debug and must be handled carefully to avoid shooting yourself in the foot.
Example usage:
await foreach (var batch in SomeAsyncEnumerable()
.ToBatchedAsyncEnumerable(batchSize: batchSize,
batchTimeout: TimeSpan.FromMilliseconds(500),
cancellationToken))
{
// process your batch
}
How it works
Given example (Test_Example_Batch_Usage) where we set batchSize
to 5 and batchTimeout
to 500ms we can see the output od processing.
Start
15:14:49.3935344 - Reading underlying item 1
15:14:49.4089621 - Reading underlying item 2
15:14:49.4244730 - Reading underlying item 3
15:14:49.4399959 - Reading underlying item 4
15:14:49.4554766 - Reading underlying item 5
15:14:49.4567448 - Processing batch of size 5 for 1 second simulated
15:14:49.4709696 - Reading underlying item 6
15:14:49.4865186 - Reading underlying item 7
15:14:49.5017162 - Reading underlying item 8
15:14:49.5169993 - Reading underlying item 9
15:14:49.5326119 - Reading underlying item 10
15:14:49.5481148 - Reading underlying item 11
15:14:50.4572927 - Batch of 5 processed
15:14:50.4578585 - Processing batch of size 5 for 1 second simulated
15:14:50.4723612 - Reading underlying item 12
15:14:51.4594741 - Batch of 5 processed
15:14:51.4596284 - Processing batch of size 2 for 1 second simulated
15:14:52.4623563 - Batch of 2 processed
Done
YOu can see that while we are processing batch next items are being enumerated asynchronously from underlying enumerable to achieve better throughput. Batch will be yielded either when specified batchSize
is reached or if batchTimeout
elapsed.
Product | Versions 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 was computed. 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 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.1 is compatible. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.1
- System.Threading.Tasks.Dataflow (>= 8.0.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Fixed README link.