ValueCollections 4.2.0

dotnet add package ValueCollections --version 4.2.0
                    
NuGet\Install-Package ValueCollections -Version 4.2.0
                    
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="ValueCollections" Version="4.2.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="ValueCollections" Version="4.2.0" />
                    
Directory.Packages.props
<PackageReference Include="ValueCollections" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add ValueCollections --version 4.2.0
                    
#r "nuget: ValueCollections, 4.2.0"
                    
#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.
#addin nuget:?package=ValueCollections&version=4.2.0
                    
Install ValueCollections as a Cake Addin
#tool nuget:?package=ValueCollections&version=4.2.0
                    
Install ValueCollections as a Cake Tool

ValueCollections

NuGet

A set of collections in C# implemented as ref struct to minimize heap allocations.

ValueList

An implementation of IList<T> using spans and array pools.

using ValueList<int> numbers = [];

for (int n = 0; n < 10; n++) {
    numbers.Add(n);
}

using ValueList<int> evenNumbers = numbers.Where(number => number % 2 == 0);

Console.WriteLine(string.Join(", ", evenNumbers.ToList())); // 0, 2, 4, 6, 8

ValueHashSet

An implementation of ISet<T> using spans and array pools.

using ValueHashSet<int> numbers = [];

for (int n = 1; n <= 5; n++) {
    numbers.Add(n);
}
for (int n = 3; n <= 7; n++) {
    numbers.Add(n);
}

Console.WriteLine(string.Join(", ", numbers.ToArray())); // 1, 2, 3, 4, 5, 6, 7

ValueDictionary

An implementation of IDictionary<TKey, TValue> using spans and array pools.

using ValueDictionary<string, string> strings = [];

strings.Add("food", "pizza");
strings.Add("drink", "cola");

Console.WriteLine(string.Join(", ", strings.ToArray())); // [food, pizza], [drink, cola]

Benchmarks

Method Mean Error StdDev Gen0 Allocated
SmallListOfStruct 16.96 ns 0.139 ns 0.130 ns 0.0255 80 B
SmallValueListOfStruct 17.28 ns 0.064 ns 0.060 ns - -
SmallListOfClass 24.76 ns 0.374 ns 0.350 ns 0.0306 96 B
SmallValueListOfClass 21.49 ns 0.193 ns 0.180 ns - -
LargeListOfStruct 21,227.63 ns 170.160 ns 159.168 ns 41.6565 131400 B
LargeValueListOfStruct 9,559.52 ns 126.272 ns 118.115 ns - 2 B
Method Mean Error StdDev Gen0 Gen1 Gen2 Allocated
SmallHashSetOfStruct 93.25 ns 0.644 ns 0.538 ns 0.1070 - - 336 B
SmallValueHashSetOfStruct 140.43 ns 1.252 ns 1.171 ns - - - -
SmallHashSetOfClass 134.52 ns 1.164 ns 1.089 ns 0.1173 - - 368 B
SmallValueHashSetOfClass 192.37 ns 0.353 ns 0.330 ns - - - -
LargeHashSetOfStruct 229,623.24 ns 1,678.047 ns 1,487.545 ns 460.2051 460.2051 76.9043 538650 B
LargeValueHashSetOfStruct 228,776.38 ns 709.610 ns 629.051 ns - - - 32 B
Method Mean Error StdDev Gen0 Gen1 Gen2 Allocated
SmallDictionaryOfStructs 100.6 ns 0.60 ns 0.56 ns 0.1223 - - 384 B
SmallValueDictionaryOfStructs 124.9 ns 0.68 ns 0.64 ns - - - -
SmallDictionaryOfClasses 154.5 ns 1.68 ns 1.31 ns 0.1478 - - 464 B
SmallValueDictionaryOfClasses 216.0 ns 0.69 ns 0.61 ns - - - -
LargeDictionaryOfStructs 217,012.6 ns 496.10 ns 439.78 ns 367.6758 367.6758 105.2246 673203 B
LargeValueDictionaryOfStructs 286,426.3 ns 1,705.62 ns 1,511.99 ns - - - 193 B

Gotchas

Value collections should be disposed after use, otherwise the internal rented array will not be returned to the pool.

using ValueList<string> strings = ["a", "b", "c"];
using ValueList<string> whitespaceStrings = strings.Where(string.IsNullOrWhiteSpace);
using ValueList<string> shortWhitespaceStrings = whitespaceStrings.Where(str => str.Length <= 10);

Special Thanks

Product Compatible and additional computed target framework versions.
.NET 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.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net8.0

    • No dependencies.
  • net9.0

    • No dependencies.

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
4.2.0 98 5/8/2025
4.1.0 97 5/8/2025
4.0.0 94 5/8/2025
3.2.0 128 4/1/2025
3.1.0 120 3/31/2025
3.0.0 123 3/31/2025
2.1.0 436 3/26/2025
2.0.0 245 3/24/2025
1.3.0 240 3/23/2025
1.2.0 242 3/23/2025
1.1.0 235 3/23/2025
1.0.0 239 3/23/2025