SortedList<TKey, TValue> Constructor (Int32, IComparer<TKey>^)
Initializes a new instance of the SortedList<TKey, TValue> class that is empty, has the specified initial capacity, and uses the specified IComparer<T>.
Assembly: System (in System.dll)
Parameters
- capacity
-
Type:
System::Int32
The initial number of elements that the SortedList<TKey, TValue> can contain.
- comparer
-
Type:
System.Collections.Generic::IComparer<TKey>^
The IComparer<T> implementation to use when comparing keys.
-or-
null to use the default Comparer<T> for the type of the key.
| Exception | Condition |
|---|---|
| ArgumentOutOfRangeException | capacity is less than zero. |
Every key in a SortedList<TKey, TValue> must be unique according to the specified comparer.
The capacity of a SortedList<TKey, TValue> is the number of elements that the SortedList<TKey, TValue> can hold before resizing. As elements are added to a SortedList<TKey, TValue>, the capacity is automatically increased as required by reallocating the internal array.
If the size of the collection can be estimated, specifying the initial capacity eliminates the need to perform a number of resizing operations while adding elements to the SortedList<TKey, TValue>.
The capacity can be decreased by calling TrimExcess or by setting the Capacity property explicitly. Decreasing the capacity reallocates memory and copies all the elements in the SortedList<TKey, TValue>.
This constructor is an O(n) operation, where n is capacity.
The following code example creates a sorted list with an initial capacity of 5 and a case-insensitive comparer for the current culture. The example adds four elements, some with lower-case keys and some with upper-case keys. The example then attempts to add an element with a key that differs from an existing key only by case, catches the resulting exception, and displays an error message. Finally, the example displays the elements in case-insensitive sort order.
Available since 10
.NET Framework
Available since 2.0