Home
C#
ImmutableList Use
Updated Sep 26, 2024
Dot Net Perls
ImmutableList. Code often acts on Lists under the assumption that the elements in the List will not be changed. But occasionally a mistake is made and the List is changed unexpectedly.
This can cause problems and incorrect program output. It is possible to ensure the List is never changed throughout runtime by using ImmutableList instead.
List
Example. In .NET we find many immutable collections, not just ImmutableList but also ImmutableArray and ImmutableDictionary. None of them can be modified at runtime.
Part 1 Often we will want to use immutable collections as fields in a class. The readonly keyword ensures the field reference is also not changed.
readonly
Part 2 We can use the Length property on an ImmutableArray. It is also possible to loop over the elements with foreach, just like other arrays.
Part 3 The elements in an ImmutableList can be accessed and enumerated like other Lists.
Part 4 As with the other immutable collections, we can access the elements in an ImmutableDictionary.
Part 5 When we call a method like Add on an ImmutableList, the method creates a modified copy of the underlying data and returns the copy.
using System; using System.Collections.Generic; using System.Collections.Immutable; class Program { // Part 1: use immutable collections as fields. static readonly ImmutableArray<string> _colors = ["blue", "aqua", "cerulean"]; static readonly ImmutableList<int> _sizes = [10, 20, 15, 0]; static readonly ImmutableDictionary<string, bool> _items = ImmutableDictionary.CreateRange( [KeyValuePair.Create("computer", true), KeyValuePair.Create("desk", false), KeyValuePair.Create("monitor", true)]); public static void Main() { // Part 2: display strings in ImmutableArray. Console.WriteLine("ARRAY LENGTH: {0}", _colors.Length); foreach (string value in _colors) { Console.WriteLine(value); } // Part 3: loop over ImmutableList. Console.WriteLine("LIST COUNT: {0}", _sizes.Count); foreach (int value in _sizes) { Console.WriteLine(value); } // Part 4: loop over ImmutableDictionary. Console.WriteLine("DICTIONARY COUNT: {0}", _items.Count); foreach (var pair in _items) { Console.WriteLine(pair); } // Part 5: call Add on ImmutableList, creating a new immutable collection copy. var sizesPlusOne = _sizes.Add(700); Console.WriteLine("LIST COUNT: {0}", _sizes.Count); Console.WriteLine("LIST+1 COUNT: {0}", sizesPlusOne.Count); foreach (int value in sizesPlusOne) { Console.WriteLine(value); } } }
ARRAY LENGTH: 3 blue aqua cerulean LIST COUNT: 4 10 20 15 0 DICTIONARY COUNT: 3 [monitor, True] [desk, False] [computer, True] LIST COUNT: 4 LIST+1 COUNT: 5 10 20 15 0 700
The benefit of collections like ImmutableList is compiler-checking: the compiler enforces that no elements can be changed. Code can act with less concern for unexpected data changes.
Dot Net Perls is a collection of pages with code examples, which are updated to stay current. Programming is an art, and it can be learned from examples.
Donate to this site to help offset the costs of running the server. Sites like this will cease to exist if there is no financial support for them.
Sam Allen is passionate about computer languages, and he maintains 100% of the material available on this website. He hopes it makes the world a nicer place.
This page was last updated on Sep 26, 2024 (new).
Home
Changes
© 2007-2025 Sam Allen