Enhanced C#
Language of your choice: library documentation
|
A compact patricia trie that uses byte arrays as keys. More...
A compact patricia trie that uses byte arrays as keys.
TValue | Type of value associated with each key. |
Nested classes | |
class | Enumerator |
Public fields | |
TValue this[byte[] | key |
Finds the specified key and returns its associated value. If the key did not exist, TryGetValue returns defaultValue instead. More... | |
Properties | |
ICollection< byte[]> | Keys [get] |
CPValueCollection< TValue > | Values [get] |
new int | Count [get] |
bool | IsReadOnly [get] |
bool | IsEmpty [get] |
Properties inherited from Loyc.Collections.IIndexed< byte[], TValue > | |
V | this[K key] [get] |
Gets the value associated with the specified key. More... | |
Public Member Functions | |
CPByteTrie (CPTrie< TValue > clone) | |
new int | CountMemoryUsage (int sizeOfT) |
void | Add (byte[] key, TValue value) |
Adds the specified key-value pair to the trie, throwing an exception if the key is already present. More... | |
void | Add (byte[] key, int offset, int length, TValue value) |
Adds the specified key-value pair to the trie, throwing an exception if the key is already present. More... | |
bool | TryAdd (byte[] key, TValue value) |
Adds the specified key-value pair only if the specified key is not already present in the trie. More... | |
bool | TryAdd (byte[] key, int offset, int length, TValue value) |
bool | TryAdd (byte[] key, int offset, int length, ref TValue value) |
Adds the specified key-value pair only if the specified key is not already present in the trie. More... | |
bool | ContainsKey (byte[] key) |
Searches for the specified key, returning true if it is present in the trie. More... | |
bool | ContainsKey (byte[] key, int offset, int length) |
Searches for the specified key, returning true if it is present in the trie. More... | |
bool | Remove (byte[] key) |
Removes the specified key and associated value, returning true if the entry was found and removed. More... | |
bool | Remove (byte[] key, int offset, int length) |
bool | Remove (byte[] key, int offset, int length, ref TValue oldValue) |
Removes the specified key and associated value, returning true if the entry was found and removed. More... | |
bool | TryGetValue (byte[] key, out TValue value) |
Finds the specified key and gets its associated value, returning true if the key was found. More... | |
bool | TryGetValue (byte[] key, int offset, int length, out TValue value) |
void | Add (KeyValuePair< byte[], TValue > item) |
new void | Clear () |
bool | Contains (KeyValuePair< byte[], TValue > item) |
void | CopyTo (KeyValuePair< byte[], TValue >[] array, int arrayIndex) |
bool | Remove (KeyValuePair< byte[], TValue > item) |
Enumerator | GetEnumerator () |
Enumerator | FindAtLeast (byte[] key) |
Enumerator | FindExact (byte[] key) |
bool | Find (byte[] key, out Enumerator e) |
bool | Find (byte[] key, int offset, int length, out Enumerator e) |
CPByteTrie< TValue > | Clone () |
Public Member Functions inherited from Loyc.Collections.CPTrie< TValue > | |
CPTrie (CPTrie< T > copy) | |
Additional Inherited Members | |
Protected Member Functions inherited from Loyc.Collections.CPTrie< TValue > | |
bool | Find (ref KeyWalker key, CPEnumerator< T > e) |
bool | Find (ref KeyWalker key, ref T value) |
Retrieves the value associated with the specified key; does nothing if the key does not exist. More... | |
bool | ContainsKey (ref KeyWalker key) |
bool | Set (ref KeyWalker key, ref T value, CPMode mode) |
Associates the specified value with the specified key. More... | |
bool | Remove (ref KeyWalker key, ref T value) |
Removes the specified key and associated value. More... | |
bool | Remove (ref KeyWalker key) |
void | Clear () |
int | CountMemoryUsage (int sizeOfT) |
Calculates the memory usage of this object, assuming a 32-bit architecture. More... | |
Static Protected Member Functions inherited from Loyc.Collections.CPTrie< TValue > | |
static StringBuilder | BytesToStringBuilder (byte[] key, int keyLength) |
Protected static fields inherited from Loyc.Collections.CPTrie< TValue > | |
static Comparer< T > | DefaultComparer |
|
inline |
Adds the specified key-value pair to the trie, throwing an exception if the key is already present.
key | An array that contains the key to add. The offset and length parameters specify a substring of this array to use as the key. |
References Loyc.Collections.Impl.CPByteTrie< TValue >.key, and Loyc.Localize.Localized().
|
inline |
Adds the specified key-value pair to the trie, throwing an exception if the key is already present.
References Loyc.Collections.Impl.CPByteTrie< TValue >.key, and Loyc.Localize.Localized().
|
inline |
Searches for the specified key, returning true if it is present in the trie.
References Loyc.Collections.Impl.CPByteTrie< TValue >.key.
|
inline |
Searches for the specified key, returning true if it is present in the trie.
key | An array that contains the key to find. The offset and length parameters specify a substring of this array to use as the key. |
References Loyc.Collections.Impl.CPByteTrie< TValue >.key.
|
inline |
Removes the specified key and associated value, returning true if the entry was found and removed.
References Loyc.Collections.Impl.CPByteTrie< TValue >.key.
|
inline |
Removes the specified key and associated value, returning true if the entry was found and removed.
key | An array that contains the key to find. The offset and length parameters specify a substring of this array to use as the key. |
oldValue | If the key is found, the associated value is assigned to this parameter. Otherwise, this parameter is not changed. |
References Loyc.Collections.Impl.CPByteTrie< TValue >.key.
|
inline |
Adds the specified key-value pair only if the specified key is not already present in the trie.
key | An array that contains the key to find. The offset and length parameters specify a substring of this array to use as the key. |
value | On entry, value specifies the value to associate with the specified key, but if the key already exists, value is changed to the value associated with the existing key. |
References Loyc.Collections.Impl.CPByteTrie< TValue >.key.
|
inline |
Adds the specified key-value pair only if the specified key is not already present in the trie.
value | A value to associate with the specified key if the key does not already exist. |
References Loyc.Collections.Impl.CPByteTrie< TValue >.key.
|
inline |
Finds the specified key and gets its associated value, returning true if the key was found.
References Loyc.Collections.Impl.CPByteTrie< TValue >.key.
|
getset |
Finds the specified key and returns its associated value. If the key did not exist, TryGetValue returns defaultValue instead.
Referenced by Loyc.Collections.Impl.CPByteTrie< TValue >.Add(), Loyc.Collections.Impl.CPByteTrie< TValue >.ContainsKey(), Loyc.Collections.Impl.CPByteTrie< TValue >.Remove(), Loyc.Collections.Impl.CPByteTrie< TValue >.TryAdd(), and Loyc.Collections.Impl.CPByteTrie< TValue >.TryGetValue().