NonBlocking 1.1.2

Implementation of a lock-free dictionary on .Net

     Included types:
     === NonBlocking.ConcurrentDictionary
     Lock-free, wait-free implementation of a dictionary.
     - has the same API as System.Collections.Concurrent.ConcurrentDictionary.
     - No locks are taken during any operation including Get, Add, Remove, internal resizes etc...
     - While multiple threads accessing NonBlocking dictionary will help each other in operations such as table resizing, there is no dependency on such behavior. If any thread get unscheduled or delayed for whatever reason, other threads will be able to make progress independently.
     - NonBlocking dictionary scales linearly with the number of active threads if hardware permits.

     On most operations NonBlocking dictionary is faster than Concurrent, especially in write-heavy scenarios.

     Core algorithms are based on NonBlockingHashMap, written and released to the public domain by Dr. Cliff Click. A good overview could be found here:

     === Counter32
     === Counter64
     Low-overhead scalable counters.

Install-Package NonBlocking -Version 1.1.2
dotnet add package NonBlocking --version 1.1.2
<PackageReference Include="NonBlocking" Version="1.1.2" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add NonBlocking --version 1.1.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.

Release Notes

Some performance improvements.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version History

Version Downloads Last updated
1.1.2 127 5/21/2020
1.1.1 355 5/14/2020
1.1.0 141 5/7/2020
1.0.3 10,473 2/13/2019
1.0.2 32,720 1/20/2018
1.0.0 674 7/20/2017
1.0.0-rc7 444 7/14/2017
1.0.0-rc6 630 5/19/2017
1.0.0-rc5 552 5/19/2017
1.0.0-rc4 598 5/10/2017