NTDLS.DelegateThreadPooling
1.2.8
See the version list below for details.
dotnet add package NTDLS.DelegateThreadPooling --version 1.2.8
NuGet\Install-Package NTDLS.DelegateThreadPooling -Version 1.2.8
<PackageReference Include="NTDLS.DelegateThreadPooling" Version="1.2.8" />
paket add NTDLS.DelegateThreadPooling --version 1.2.8
#r "nuget: NTDLS.DelegateThreadPooling, 1.2.8"
// Install NTDLS.DelegateThreadPooling as a Cake Addin #addin nuget:?package=NTDLS.DelegateThreadPooling&version=1.2.8 // Install NTDLS.DelegateThreadPooling as a Cake Tool #tool nuget:?package=NTDLS.DelegateThreadPooling&version=1.2.8
NTDLS.DelegateThreadPooling
📦 Be sure to check out the NuGet pacakge: https://www.nuget.org/packages/NTDLS.DelegateThreadPooling
High performance active thread pool where work items can be queued as delegate functions. Allows you to easily enqueue infinite FIFO worker items or enforce queue size, wait on collections of those items to complete, and total control over the pool size. Also allows for multiple pools, so that different workloads do not interfere with one another.
If you have ever been frustrated with System.Threading.ThreadPool, then this is likely the solution you are looking for.
private static readonly DelegateThreadPool _delegateThreadPool = new(10);
static void Main()
{
CollectionExample();
NoCollectionExample();
Console.WriteLine("Press [enter] to exit.");
Console.ReadLine();
_delegateThreadPool.Dispose();
}
private static void CollectionExample()
{
Console.WriteLine("CollectionExample: Starting to enqueue items...");
var queuedStates = _delegateThreadPool.CreateQueueStateCollection();
//Enqueue work items as delegate functions.
for (int i = 0; i < 100; i++)
{
queuedStates.Enqueue(() =>
{
Thread.Sleep(1000); //Do some work...
});
}
Console.WriteLine("Enqueue complete, waiting on completion.");
//Wait on all of the workitems to complete.
queuedStates.WaitForCompletion();
Console.WriteLine("All workers are complete.");
}
private static void NoCollectionExample()
{
Console.WriteLine("NoCollectionExample: Starting to enqueue items...");
var queueTokens = new List<QueueItemState>();
//Enqueue work items as delegate functions.
for (int i = 0; i < 100; i++)
{
var queueItemState = _delegateThreadPool.Enqueue(() =>
{
Thread.Sleep(1000); //Do some work...
});
queueTokens.Add(queueItemState);
}
Console.WriteLine("Enqueue complete, waiting on completion.");
//Wait on all of the workitems to complete.
queueTokens.ForEach(t => t.WaitForCompletion());
Console.WriteLine("All workers are complete.");
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. 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 is compatible. 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. |
-
net6.0
- NTDLS.Semaphore (>= 3.3.0)
-
net7.0
- NTDLS.Semaphore (>= 3.3.0)
-
net8.0
- NTDLS.Semaphore (>= 3.3.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.5.8 | 89 | 10/22/2024 |
1.5.7 | 80 | 10/20/2024 |
1.5.6 | 94 | 10/20/2024 |
1.5.5 | 90 | 10/13/2024 |
1.5.4 | 87 | 10/13/2024 |
1.5.3 | 83 | 10/13/2024 |
1.5.1 | 93 | 10/8/2024 |
1.5.0 | 89 | 10/3/2024 |
1.4.9 | 86 | 10/3/2024 |
1.4.8 | 159 | 8/25/2024 |
1.4.7 | 137 | 8/24/2024 |
1.4.6 | 112 | 8/23/2024 |
1.4.5 | 111 | 8/23/2024 |
1.4.4 | 124 | 8/13/2024 |
1.4.3 | 120 | 8/13/2024 |
1.4.2 | 120 | 8/13/2024 |
1.4.1 | 119 | 8/13/2024 |
1.4.0 | 113 | 8/12/2024 |
1.3.6 | 110 | 8/9/2024 |
1.3.5 | 104 | 8/9/2024 |
1.3.4 | 103 | 8/9/2024 |
1.3.3 | 113 | 8/9/2024 |
1.3.2 | 81 | 8/6/2024 |
1.3.1 | 82 | 8/6/2024 |
1.3.0 | 72 | 8/6/2024 |
1.2.15 | 122 | 6/20/2024 |
1.2.14 | 120 | 6/20/2024 |
1.2.13 | 193 | 3/12/2024 |
1.2.12 | 177 | 3/12/2024 |
1.2.11 | 268 | 2/22/2024 |
1.2.10 | 232 | 2/20/2024 |
1.2.9 | 308 | 1/24/2024 |
1.2.8 | 306 | 1/24/2024 |
1.2.7 | 302 | 1/24/2024 |
1.2.6 | 278 | 1/22/2024 |
1.2.5 | 295 | 1/22/2024 |
1.2.4 | 319 | 1/22/2024 |
1.2.3 | 320 | 1/22/2024 |
1.2.2 | 272 | 1/22/2024 |
Added default thread count, support for aborting queued items and changing spin and wait times.
Added exception handling and thread count growth.
Added maximum queue depth enforcement.
Added parameterized delegate support.
Added collection parametrization.
Added collection exception handling.
Added collection pruning.
Added infinite wait and sleep ceiling burndown for balanced idle CPU time and performance.
Corrected default wait time.