- Type Parameters:
- K- key type
- V- value type
- All Implemented Interfaces:
- MapWithOrdinal<K,- V> 
This class extends the functionality a regular Map with ordinal lookup support. Upon
 insertion an unused ordinal is assigned to the inserted (key, value) tuple. Upon update the same
 ordinal id is re-used while value is replaced. Upon deletion of an existing item, its
 corresponding ordinal is recycled and could be used by another item.
 
For any instance with N items, this implementation guarantees that ordinals are in the range
 of [0, N). However, the ordinal assignment is dynamic and may change after an insertion or
 deletion. Consumers of this class are responsible for explicitly checking the ordinal
 corresponding to a key via getOrdinal(Object) before attempting to
 execute a lookup with an ordinal.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidclear()booleancontainsKey(K key) get set of values for key.get set of values for key.getByOrdinal(int id) Returns the value corresponding to the given ordinal.intgetOrdinal(K key) Returns the ordinal corresponding to the given key.booleanisEmpty()keys()booleanInserts the tuple (key, value) into the multimap with automatic ordinal assignment.booleanRemoves the element corresponding to the key/value if exists with ordinal re-cycling.booleanremove all entries of key.intsize()values()
- 
Constructor Details- 
MultiMapWithOrdinalpublic MultiMapWithOrdinal()
 
- 
- 
Method Details- 
getByOrdinalReturns the value corresponding to the given ordinal.- Specified by:
- getByOrdinalin interface- MapWithOrdinal<K,- V> 
- Parameters:
- id- ordinal value for lookup
- Returns:
- an instance of V
 
- 
getOrdinalReturns the ordinal corresponding to the given key.- Specified by:
- getOrdinalin interface- MapWithOrdinal<K,- V> 
- Parameters:
- key- key for ordinal lookup
- Returns:
- ordinal value corresponding to key if it exists or -1
 
- 
sizepublic int size()- Specified by:
- sizein interface- MapWithOrdinal<K,- V> 
 
- 
isEmptypublic boolean isEmpty()- Specified by:
- isEmptyin interface- MapWithOrdinal<K,- V> 
 
- 
getget set of values for key.- Specified by:
- getin interface- MapWithOrdinal<K,- V> 
 
- 
getAllget set of values for key.- Specified by:
- getAllin interface- MapWithOrdinal<K,- V> 
 
- 
putInserts the tuple (key, value) into the multimap with automatic ordinal assignment.A new ordinal is assigned if key/value pair does not exists. If overwrite is true the existing key will be overwritten with value else value will be appended to the multimap. - Specified by:
- putin interface- MapWithOrdinal<K,- V> 
 
- 
values- Specified by:
- valuesin interface- MapWithOrdinal<K,- V> 
 
- 
containsKey- Specified by:
- containsKeyin interface- MapWithOrdinal<K,- V> 
 
- 
removeRemoves the element corresponding to the key/value if exists with ordinal re-cycling.The ordinal corresponding to the given key may be re-assigned to another tuple. It is important that consumer checks the ordinal value via getOrdinal(Object)before attempting to look-up by ordinal.If the multimap is changed return true. - Specified by:
- removein interface- MapWithOrdinal<K,- V> 
 
- 
removeAllremove all entries of key.- Specified by:
- removeAllin interface- MapWithOrdinal<K,- V> 
 
- 
clearpublic void clear()- Specified by:
- clearin interface- MapWithOrdinal<K,- V> 
 
- 
keys- Specified by:
- keysin interface- MapWithOrdinal<K,- V> 
 
 
-