Class ValueList<T>
- Namespace
- Badeend.ValueCollections
- Assembly
- Badeend.ValueCollections.dll
An immutable, thread-safe list with value semantics.
public sealed class ValueList<T> : IReadOnlyList<T>, IReadOnlyCollection<T>, IList<T>, ICollection<T>, IEnumerable<T>, IEnumerable, IEquatable<ValueList<T>>, IComparable, IComparable<ValueList<T>>
Type Parameters
T
The type of items in the list.
- Inheritance
-
ValueList<T>
- Implements
-
IList<T>ICollection<T>IEnumerable<T>IEquatable<ValueList<T>>IComparable<ValueList<T>>
- Inherited Members
- Extension Methods
Remarks
Constructing new instances can be done using CreateBuilder<T>() or ToBuilder(). For creating ValueLists, ValueList<T>.Builder is generally more efficient than List<T>.
ValueLists have "structural equality". This means that two lists are considered equal only when their contents are equal. As long as a value is present in a ValueList, its hash code may not change.
Taking a subslice with Slice(int) and Slice(int, int) is very cheap as it reuses the same allocation.
Properties
Count
Length of the list.
[Pure]
public int Count { get; }
Property Value
Empty
Get an empty list.
This does not allocate any memory.
[Pure]
public static ValueList<T> Empty { get; }
Property Value
- ValueList<T>
IsEmpty
Shortcut for .Count == 0
.
[Pure]
public bool IsEmpty { get; }
Property Value
this[int]
Get an item from the list at the specified index
.
public ref readonly T this[int index] { get; }
Parameters
index
int
Property Value
- T
Methods
AsMemory()
Access the list's contents using a ReadOnlyMemory<T>.
[Pure]
public ReadOnlyMemory<T> AsMemory()
Returns
AsSpan()
Access the list's contents using a ReadOnlySpan<T>.
[Pure]
public ReadOnlySpan<T> AsSpan()
Returns
- ReadOnlySpan<T>
AsValueSlice()
Access the list's contents using a ValueSlice<T>.
[Pure]
public ValueSlice<T> AsValueSlice()
Returns
- ValueSlice<T>
BinarySearch(T)
Perform a binary search for item
within the list.
The list is assumed to already be sorted. This uses the
Default comparer and throws if
T
is not comparable. If the item is found, its
index is returned. Otherwise a negative value is returned representing
the bitwise complement of the index where the item was expected.
[Pure]
public int BinarySearch(T item)
Parameters
item
T
Returns
CompareTo(ValueList<T>?)
Compare two lists based on their contents using lexicographic ordering
(the same algorithm used by MemoryExtensions.SequenceCompareTo
).
[Pure]
public int CompareTo(ValueList<T>? other)
Parameters
other
ValueList<T>
Returns
- int
See IComparable<T>.CompareTo(T) for more information.
Exceptions
- ArgumentException
T
does not implement IComparable.
Contains(T)
Returns true when the list contains the specified
item
.
[Pure]
public bool Contains(T item)
Parameters
item
T
Returns
CopyTo(Span<T>)
Copy the contents of the list into an existing Span<T>.
public void CopyTo(Span<T> destination)
Parameters
destination
Span<T>
Exceptions
- ArgumentException
destination
is shorter than the source slice.
Equals(ValueList<T>?)
Returns true when the two lists have identical length and content.
[Pure]
public bool Equals(ValueList<T>? other)
Parameters
other
ValueList<T>
Returns
GetEnumerator()
Returns an enumerator for this ValueList<T>.
Typically, you don't need to manually call this method, but instead use
the built-in foreach
syntax.
[Pure]
public ValueList<T>.Enumerator GetEnumerator()
Returns
GetHashCode()
Serves as the default hash function.
[Pure]
public override sealed int GetHashCode()
Returns
- int
A hash code for the current object.
IndexOf(T)
Return the index of the first occurrence of item
in
the list, or -1
if not found.
[Pure]
public int IndexOf(T item)
Parameters
item
T
Returns
LastIndexOf(T)
Return the index of the last occurrence of item
in
the list, or -1
if not found.
[Pure]
public int LastIndexOf(T item)
Parameters
item
T
Returns
Slice(int)
Create a subslice, starting at offset
.
[Pure]
public ValueSlice<T> Slice(int offset)
Parameters
offset
intThe index at which to begin the subslice.
Returns
- ValueSlice<T>
Remarks
This is an O(1)
operation and does not allocates any memory.
Exceptions
- ArgumentOutOfRangeException
offset
is below0
or greater than the current list's length.
Slice(int, int)
Create a subslice with a specified length
,
starting at offset
.
[Pure]
public ValueSlice<T> Slice(int offset, int length)
Parameters
Returns
- ValueSlice<T>
Remarks
This is an O(1)
operation and does not allocates any memory.
Exceptions
- ArgumentOutOfRangeException
offset
is below0
or greater than the current list's length.- ArgumentOutOfRangeException
length
is below0
or would extend beyond the current list's length.
ToArray()
Copy the contents of the list into a new array.
[Pure]
public T[] ToArray()
Returns
- T[]
ToBuilder()
Create a new ValueList<T>.Builder with this list as its initial content. This builder can then be used to efficiently construct a new immutable ValueList<T>.
[Pure]
public ValueList<T>.Builder ToBuilder()
Returns
Remarks
The capacity of the returned builder may be larger than the size of this list. How much larger exactly is undefined.
ToString()
Get a string representation of the collection for debugging purposes. The format is not stable and may change without prior notice.
[Pure]
public override string ToString()
Returns
TryCopyTo(Span<T>)
Attempt to copy the contents of the list into an existing
Span<T>. If the destination
is too short,
no items are copied and the method returns false.
public bool TryCopyTo(Span<T> destination)
Parameters
destination
Span<T>
Returns
Operators
operator ==(ValueList<T>?, ValueList<T>?)
Check for equality.
[Pure]
public static bool operator ==(ValueList<T>? left, ValueList<T>? right)
Parameters
Returns
implicit operator ValueSlice<T>(ValueList<T>)
Access the list as a ValueSlice<T>.
[Pure]
public static implicit operator ValueSlice<T>(ValueList<T> list)
Parameters
list
ValueList<T>
Returns
- ValueSlice<T>
implicit operator ReadOnlyMemory<T>(ValueList<T>)
Access the list as a ReadOnlyMemory<T>.
[Pure]
public static implicit operator ReadOnlyMemory<T>(ValueList<T> list)
Parameters
list
ValueList<T>
Returns
implicit operator ReadOnlySpan<T>(ValueList<T>)
Access the list as a ReadOnlySpan<T>.
[Pure]
public static implicit operator ReadOnlySpan<T>(ValueList<T> list)
Parameters
list
ValueList<T>
Returns
- ReadOnlySpan<T>
operator !=(ValueList<T>?, ValueList<T>?)
Check for inequality.
[Pure]
public static bool operator !=(ValueList<T>? left, ValueList<T>? right)