Class LongShortHashMap
- java.lang.Object
-
- org.eclipse.collections.impl.primitive.AbstractShortIterable
-
- org.eclipse.collections.impl.map.mutable.primitive.AbstractMutableShortValuesMap
-
- org.eclipse.collections.impl.map.mutable.primitive.LongShortHashMap
-
- All Implemented Interfaces:
java.io.Externalizable,java.io.Serializable,LongShortMap,MutableLongShortMap,MutableShortValuesMap,ShortValuesMap,PrimitiveIterable,ShortIterable,MutableLongKeysMap,LongKeysMap
public class LongShortHashMap extends AbstractMutableShortValuesMap implements MutableLongShortMap, java.io.Externalizable, MutableLongKeysMap
This file was automatically generated from template file primitivePrimitiveHashMap.stg.- Since:
- 3.0.
- See Also:
- Serialized Form
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description private classLongShortHashMap.InternalShortIteratorprivate classLongShortHashMap.KeySetprivate classLongShortHashMap.KeySetIteratorprivate classLongShortHashMap.KeysViewprivate classLongShortHashMap.KeyValuesViewprivate classLongShortHashMap.ValuesCollection-
Nested classes/interfaces inherited from class org.eclipse.collections.impl.map.mutable.primitive.AbstractMutableShortValuesMap
AbstractMutableShortValuesMap.AbstractShortValuesCollection, AbstractMutableShortValuesMap.SentinelValues
-
-
Field Summary
Fields Modifier and Type Field Description private static intCACHE_LINE_SIZEprivate booleancopyKeysOnWriteprivate static intDEFAULT_INITIAL_CAPACITYprivate static longEMPTY_KEYprivate static shortEMPTY_VALUEprivate static intINITIAL_LINEAR_PROBEprivate static intKEY_SIZEprivate long[]keysprivate intoccupiedWithDataprivate intoccupiedWithSentinelsprivate static longREMOVED_KEYprivate AbstractMutableShortValuesMap.SentinelValuessentinelValuesprivate static longserialVersionUIDprivate short[]values
-
Constructor Summary
Constructors Constructor Description LongShortHashMap()LongShortHashMap(int initialCapacity)LongShortHashMap(LongShortMap map)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description private voidaddKeyValueAtIndex(long key, short value, int index)shortaddToValue(long key, short toBeAdded)Increments and updates the value associated with the key, if a value exists, or sets the value to be the specified value if one does not.protected voidallocateTable(int sizeToAllocate)booleanallSatisfyKeyValue(LongShortPredicate predicate)MutableLongShortMapasSynchronized()Returns a synchronized view of this map, delegating all operations to this map but ensuring only one caller has access to the map at a time.MutableLongShortMapasUnmodifiable()Returns an unmodifiable view of this map, delegating all read-only operations to this map and throwing anUnsupportedOperationExceptionfor all mutating operations.voidclear()Removes all entries from this map.voidcompact()Deprecated.since 12.0 - UsetrimToSize()insteadbooleancontainsKey(long key)Returns whether or not the key is present in the map.private voidcopyKeys()booleanequals(java.lang.Object obj)Follows the same general contract asMap.equals(Object).private shortfastGetIfAbsent(long key, short ifAbsent)MutableShortLongMapflipUniqueValues()Return the ShortLongMap that is obtained by flipping the direction of this map and making the associations from value to key.voidforEachKey(LongProcedure procedure)Iterates through each key in the map, invoking the procedure for each.voidforEachKeyValue(LongShortProcedure procedure)Iterates through each key/value pair in the map, invoking the procedure for each.shortget(long key)Retrieves the value associated with the key.shortgetAndPut(long key, short putValue, short defaultValue)Retrieves the value associated with the key if one exists; associates a putValue with the key.protected shortgetEmptyValue()private shortgetForSentinel(long key, short ifAbsent)shortgetIfAbsent(long key, short ifAbsent)Retrieves the value associated with the key, returning the specified default value if no such mapping exists.shortgetIfAbsentPut(long key, short value)Retrieves the value associated with the key if one exists; if it does not, associates a value with the key.shortgetIfAbsentPut(long key, ShortFunction0 function)Retrieves the value associated with the key if one exists; if it does not, invokes the supplier and associates the result with the key.<P> shortgetIfAbsentPutWith(long key, ShortFunction<? super P> function, P parameter)Retrieves the value associated with the key if one exists; if it does not, invokes the value function with the parameter and associates the result with the key.shortgetIfAbsentPutWithKey(long key, LongToShortFunction function)Retrieves the value associated with the key if one exists; if it does not, associates the result of invoking the value function with the key.protected intgetOccupiedWithData()shortgetOrThrow(long key)Retrieves the value associated with the key, throwing anIllegalStateExceptionif no such mapping exists.protected AbstractMutableShortValuesMap.SentinelValuesgetSentinelValues()protected intgetTableSize()protected shortgetValueAtIndex(int index)inthashCode()Follows the same general contract asMap.hashCode().<V> VinjectInto(V injectedValue, ObjectShortToObjectFunction<? super V,? extends V> function)private static booleanisEmptyKey(long key)private static booleanisNonSentinel(long key)protected booleanisNonSentinelAtIndex(int index)private static booleanisRemovedKey(long key)MutableLongSetkeySet()Returns a set containing all the keys in this map.LazyLongIterablekeysView()Returns a view of the keys in this map.RichIterable<LongShortPair>keyValuesView()Returns a view of the key/value pairs in this map.private intmask(int spread)private intmaxOccupiedWithData()static LongShortHashMapnewWithKeysValues(long key1, short value1)static LongShortHashMapnewWithKeysValues(long key1, short value1, long key2, short value2)static LongShortHashMapnewWithKeysValues(long key1, short value1, long key2, short value2, long key3, short value3)static LongShortHashMapnewWithKeysValues(long key1, short value1, long key2, short value2, long key3, short value3, long key4, short value4)(package private) intprobe(long element)(package private) intprobeThree(long element, int removedIndex)(package private) intprobeTwo(long element, int removedIndex)voidput(long key, short value)Associates a value with the specified key.voidputAll(LongShortMap map)Puts all of the key/value mappings from the specified map into this map.private voidputForEmptySentinel(short value)private voidputForRemovedSentinel(short value)voidreadExternal(java.io.ObjectInput in)private voidrehash(int newCapacity)private voidrehashAndGrow()LongShortHashMapreject(LongShortPredicate predicate)Return a copy of this map containing only the key/value pairs that do not match the predicate.voidremove(long key)Removes the mapping associated with the key, if one exists, from the map.voidremoveKey(long key)Removes the mapping associated with the key, if one exists, from the map.private voidremoveKeyAtIndex(int index)shortremoveKeyIfAbsent(long key, short value)Removes the mapping associated with the key, if one exists, from the map, returning the previously associated value with the key.LongShortHashMapselect(LongShortPredicate predicate)Return a copy of this map containing only the key/value pairs that match the predicate.protected voidsetSentinelValuesNull()MutableShortIteratorshortIterator()Returns a primitive iterator that can be used to iterate over the ShortIterable in an imperative style.private shortslowGetIfAbsent(long key, short ifAbsent)private shortslowGetIfAbsentTwo(long key, short ifAbsent)private intsmallestPowerOfTwoGreaterThan(int n)(package private) intspreadAndMask(long element)(package private) intspreadTwoAndMask(long element)ImmutableLongShortMaptoImmutable()Returns a copy of this map that is immutable (if this map is mutable) or itself if it is already immutable.java.lang.StringtoString()Returns a string with the elements of this iterable separated by commas with spaces and enclosed in square brackets.booleantrimToSize()shortupdateValue(long key, short initialValueIfAbsent, ShortToShortFunction function)Updates or sets the value associated with the key by applying the function to the existing value, if one exists, or to the specified initial value if one does not.voidupdateValues(LongShortToShortFunction function)Updates the values in-place.MutableShortCollectionvalues()Returns the values in this map as a separate collection.LongShortHashMapwithKeysValues(long key1, short value1, long key2, short value2)LongShortHashMapwithKeysValues(long key1, short value1, long key2, short value2, long key3, short value3)LongShortHashMapwithKeysValues(long key1, short value1, long key2, short value2, long key3, short value3, long key4, short value4)LongShortHashMapwithKeyValue(long key1, short value1)Associates a value with the specified key.LongShortHashMapwithoutAllKeys(LongIterable keys)Removes the mappings associated with all the keys, if they exist, from this map.LongShortHashMapwithoutKey(long key)Removes the mapping associated with the key, if one exists, from this map.voidwriteExternal(java.io.ObjectOutput out)-
Methods inherited from class org.eclipse.collections.impl.map.mutable.primitive.AbstractMutableShortValuesMap
addEmptyKeyValue, addRemovedKeyValue, allSatisfy, anySatisfy, appendString, chunk, collect, contains, containsAll, containsValue, count, detectIfNone, each, forEachValue, isEmpty, max, min, notEmpty, reject, removeEmptyKey, removeRemovedKey, select, size, sum, toArray, toArray
-
Methods inherited from class org.eclipse.collections.impl.primitive.AbstractShortIterable
asLazy, average, maxIfEmpty, median, minIfEmpty, toBag, toList, toSet, toSortedArray, toSortedList
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.eclipse.collections.impl.map.primitive.LongKeysMap
isEmpty, notEmpty, size
-
Methods inherited from interface org.eclipse.collections.api.map.primitive.LongShortMap
injectIntoKeyValue
-
Methods inherited from interface org.eclipse.collections.api.map.primitive.MutableLongShortMap
putPair, withAllKeyValues
-
Methods inherited from interface org.eclipse.collections.api.map.primitive.MutableShortValuesMap
collect, reject, select
-
Methods inherited from interface org.eclipse.collections.api.PrimitiveIterable
appendString, appendString, appendString, isEmpty, makeString, makeString, makeString, notEmpty, size
-
Methods inherited from interface org.eclipse.collections.api.ShortIterable
allSatisfy, anySatisfy, asLazy, average, averageIfEmpty, chunk, collect, collectBoolean, collectByte, collectChar, collectDouble, collectFloat, collectInt, collectLong, collectShort, contains, containsAll, containsAll, containsAny, containsAny, containsNone, containsNone, count, detectIfNone, each, flatCollect, forEach, injectIntoBoolean, injectIntoByte, injectIntoChar, injectIntoDouble, injectIntoFloat, injectIntoInt, injectIntoLong, injectIntoShort, max, maxIfEmpty, median, medianIfEmpty, min, minIfEmpty, noneSatisfy, reduce, reduceIfEmpty, reject, select, sum, summaryStatistics, toArray, toArray, toBag, toList, toSet, toSortedArray, toSortedList, toSortedList, toSortedListBy, toSortedListBy
-
Methods inherited from interface org.eclipse.collections.api.map.primitive.ShortValuesMap
containsValue, forEachValue, tap
-
-
-
-
Field Detail
-
EMPTY_VALUE
private static final short EMPTY_VALUE
- See Also:
- Constant Field Values
-
serialVersionUID
private static final long serialVersionUID
- See Also:
- Constant Field Values
-
EMPTY_KEY
private static final long EMPTY_KEY
- See Also:
- Constant Field Values
-
REMOVED_KEY
private static final long REMOVED_KEY
- See Also:
- Constant Field Values
-
CACHE_LINE_SIZE
private static final int CACHE_LINE_SIZE
- See Also:
- Constant Field Values
-
KEY_SIZE
private static final int KEY_SIZE
- See Also:
- Constant Field Values
-
INITIAL_LINEAR_PROBE
private static final int INITIAL_LINEAR_PROBE
- See Also:
- Constant Field Values
-
DEFAULT_INITIAL_CAPACITY
private static final int DEFAULT_INITIAL_CAPACITY
- See Also:
- Constant Field Values
-
keys
private long[] keys
-
values
private short[] values
-
occupiedWithData
private int occupiedWithData
-
occupiedWithSentinels
private int occupiedWithSentinels
-
sentinelValues
private AbstractMutableShortValuesMap.SentinelValues sentinelValues
-
copyKeysOnWrite
private boolean copyKeysOnWrite
-
-
Constructor Detail
-
LongShortHashMap
public LongShortHashMap()
-
LongShortHashMap
public LongShortHashMap(int initialCapacity)
-
LongShortHashMap
public LongShortHashMap(LongShortMap map)
-
-
Method Detail
-
newWithKeysValues
public static LongShortHashMap newWithKeysValues(long key1, short value1)
-
newWithKeysValues
public static LongShortHashMap newWithKeysValues(long key1, short value1, long key2, short value2)
-
newWithKeysValues
public static LongShortHashMap newWithKeysValues(long key1, short value1, long key2, short value2, long key3, short value3)
-
newWithKeysValues
public static LongShortHashMap newWithKeysValues(long key1, short value1, long key2, short value2, long key3, short value3, long key4, short value4)
-
smallestPowerOfTwoGreaterThan
private int smallestPowerOfTwoGreaterThan(int n)
-
getOccupiedWithData
protected int getOccupiedWithData()
- Specified by:
getOccupiedWithDatain classAbstractMutableShortValuesMap
-
getSentinelValues
protected AbstractMutableShortValuesMap.SentinelValues getSentinelValues()
- Specified by:
getSentinelValuesin classAbstractMutableShortValuesMap
-
setSentinelValuesNull
protected void setSentinelValuesNull()
- Specified by:
setSentinelValuesNullin classAbstractMutableShortValuesMap
-
getEmptyValue
protected short getEmptyValue()
- Specified by:
getEmptyValuein classAbstractMutableShortValuesMap
-
getTableSize
protected int getTableSize()
- Specified by:
getTableSizein classAbstractMutableShortValuesMap
-
getValueAtIndex
protected short getValueAtIndex(int index)
- Specified by:
getValueAtIndexin classAbstractMutableShortValuesMap
-
equals
public boolean equals(java.lang.Object obj)
Description copied from interface:LongShortMapFollows the same general contract asMap.equals(Object).- Specified by:
equalsin interfaceLongShortMap- Overrides:
equalsin classjava.lang.Object
-
hashCode
public int hashCode()
Description copied from interface:LongShortMapFollows the same general contract asMap.hashCode().- Specified by:
hashCodein interfaceLongShortMap- Overrides:
hashCodein classjava.lang.Object
-
toString
public java.lang.String toString()
Description copied from interface:PrimitiveIterableReturns a string with the elements of this iterable separated by commas with spaces and enclosed in square brackets.Assert.assertEquals("[]", IntLists.mutable.empty().toString()); Assert.assertEquals("[1]", IntLists.mutable.with(1).toString()); Assert.assertEquals("[1, 2, 3]", IntLists.mutable.with(1, 2, 3).toString());- Specified by:
toStringin interfaceLongShortMap- Specified by:
toStringin interfacePrimitiveIterable- Overrides:
toStringin classAbstractShortIterable- Returns:
- a string representation of this PrimitiveIterable
- See Also:
AbstractCollection.toString()
-
shortIterator
public MutableShortIterator shortIterator()
Description copied from interface:ShortIterableReturns a primitive iterator that can be used to iterate over the ShortIterable in an imperative style.- Specified by:
shortIteratorin interfaceMutableShortValuesMap- Specified by:
shortIteratorin interfaceShortIterable
-
injectInto
public <V> V injectInto(V injectedValue, ObjectShortToObjectFunction<? super V,? extends V> function)- Specified by:
injectIntoin interfaceShortIterable
-
clear
public void clear()
Description copied from interface:MutableShortValuesMapRemoves all entries from this map.- Specified by:
clearin interfaceMutableLongKeysMap- Specified by:
clearin interfaceMutableShortValuesMap
-
put
public void put(long key, short value)Description copied from interface:MutableLongShortMapAssociates a value with the specified key. If a value is already associated with the key in this map, it will be replaced withvalue.- Specified by:
putin interfaceMutableLongShortMap- Parameters:
key- the keyvalue- the value to associate withvalue
-
putForRemovedSentinel
private void putForRemovedSentinel(short value)
-
putForEmptySentinel
private void putForEmptySentinel(short value)
-
putAll
public void putAll(LongShortMap map)
Description copied from interface:MutableLongShortMapPuts all of the key/value mappings from the specified map into this map. If this map already has a value associated with one of the keys in the map, it will be replaced with the value inmap.- Specified by:
putAllin interfaceMutableLongShortMap- Parameters:
map- the map to copy into this map
-
updateValues
public void updateValues(LongShortToShortFunction function)
Description copied from interface:MutableLongShortMapUpdates the values in-place.- Specified by:
updateValuesin interfaceMutableLongShortMap- Parameters:
function- that takes a key and its value and that returns a new value for this key
-
removeKey
public void removeKey(long key)
Description copied from interface:MutableLongShortMapRemoves the mapping associated with the key, if one exists, from the map.- Specified by:
removeKeyin interfaceMutableLongKeysMap- Specified by:
removeKeyin interfaceMutableLongShortMap- Parameters:
key- the key to remove- See Also:
MutableLongShortMap.remove(long)
-
remove
public void remove(long key)
Description copied from interface:MutableLongShortMapRemoves the mapping associated with the key, if one exists, from the map.- Specified by:
removein interfaceMutableLongShortMap- Parameters:
key- the key to remove- See Also:
MutableLongShortMap.removeKey(long)
-
removeKeyIfAbsent
public short removeKeyIfAbsent(long key, short value)Description copied from interface:MutableLongShortMapRemoves the mapping associated with the key, if one exists, from the map, returning the previously associated value with the key. If no mapping existed for the key, the specified default value is returned.- Specified by:
removeKeyIfAbsentin interfaceMutableLongShortMap- Parameters:
key- the key to removevalue- the default value to return if no mapping for the key exists- Returns:
- the value previously associated with the key, if one existed,
or
valueif not
-
getIfAbsentPut
public short getIfAbsentPut(long key, short value)Description copied from interface:MutableLongShortMapRetrieves the value associated with the key if one exists; if it does not, associates a value with the key.- Specified by:
getIfAbsentPutin interfaceMutableLongShortMap- Parameters:
key- the keyvalue- the value to associate withkeyif no such mapping exists- Returns:
- the value associated with key, if one exists, or
valueif not
-
getAndPut
public short getAndPut(long key, short putValue, short defaultValue)Description copied from interface:MutableLongShortMapRetrieves the value associated with the key if one exists; associates a putValue with the key.- Specified by:
getAndPutin interfaceMutableLongShortMap- Parameters:
key- the keyputValue- the value to associate withkeyif no such mapping existsdefaultValue- the value to return if no mapping associated withkeyexists- Returns:
- the value associated with key, if one exists, or
defaultValueif not
-
getIfAbsentPut
public short getIfAbsentPut(long key, ShortFunction0 function)Description copied from interface:MutableLongShortMapRetrieves the value associated with the key if one exists; if it does not, invokes the supplier and associates the result with the key.- Specified by:
getIfAbsentPutin interfaceMutableLongShortMap- Parameters:
key- the keyfunction- the supplier that provides the value if no mapping exists forkey- Returns:
- the value associated with the key, if one exists, or the result of
invoking
functionif not
-
getIfAbsentPutWith
public <P> short getIfAbsentPutWith(long key, ShortFunction<? super P> function, P parameter)Description copied from interface:MutableLongShortMapRetrieves the value associated with the key if one exists; if it does not, invokes the value function with the parameter and associates the result with the key.- Specified by:
getIfAbsentPutWithin interfaceMutableLongShortMap- Type Parameters:
P- the type of the value function'sparameter- Parameters:
key- the keyfunction- the function that provides the value if no mapping exists. The specifiedparameterwill be passed as the argument to the function.parameter- the parameter to provide tofunctionif no value exists forkey- Returns:
- the value associated with the key, if one exists, or the result of
invoking
functionwithparameterif not
-
getIfAbsentPutWithKey
public short getIfAbsentPutWithKey(long key, LongToShortFunction function)Description copied from interface:MutableLongShortMapRetrieves the value associated with the key if one exists; if it does not, associates the result of invoking the value function with the key.- Specified by:
getIfAbsentPutWithKeyin interfaceMutableLongShortMap- Parameters:
key- the keyfunction- the function that provides the value if no mapping exists. Thekeywill be passed as the argument to the function.- Returns:
- the value associated with the key, if one exists, or the result of
invoking
functionwithkeyif not
-
addToValue
public short addToValue(long key, short toBeAdded)Description copied from interface:MutableLongShortMapIncrements and updates the value associated with the key, if a value exists, or sets the value to be the specified value if one does not.- Specified by:
addToValuein interfaceMutableLongShortMap- Parameters:
key- the keytoBeAdded- the amount to increment the existing value, if one exists, or to use as the initial value if one does not- Returns:
- the value after incrementing
toBeAddedto the existing value associated withkeyortoBeAddedif one does not
-
addKeyValueAtIndex
private void addKeyValueAtIndex(long key, short value, int index)
-
removeKeyAtIndex
private void removeKeyAtIndex(int index)
-
copyKeys
private void copyKeys()
-
updateValue
public short updateValue(long key, short initialValueIfAbsent, ShortToShortFunction function)Description copied from interface:MutableLongShortMapUpdates or sets the value associated with the key by applying the function to the existing value, if one exists, or to the specified initial value if one does not.- Specified by:
updateValuein interfaceMutableLongShortMap- Parameters:
key- the keyinitialValueIfAbsent- the initial value to supply to the function if no mapping exists for the keyfunction- the function that returns the updated value based on the current value or the initial value, if no value exists- Returns:
- the new value associated with the key, either as a result of applying
functionto the value already associated with the key or as a result of applying it toinitialValueIfAbsentand associating the result withkey
-
withKeyValue
public LongShortHashMap withKeyValue(long key1, short value1)
Description copied from interface:MutableLongShortMapAssociates a value with the specified key. If a value is already associated with the key in this map, it will be replaced withvalue.- Specified by:
withKeyValuein interfaceMutableLongShortMap- Parameters:
key1- the keyvalue1- the value to associate withvalue- Returns:
- this map
- See Also:
MutableLongShortMap.put(long, short)
-
withKeysValues
public LongShortHashMap withKeysValues(long key1, short value1, long key2, short value2)
-
withKeysValues
public LongShortHashMap withKeysValues(long key1, short value1, long key2, short value2, long key3, short value3)
-
withKeysValues
public LongShortHashMap withKeysValues(long key1, short value1, long key2, short value2, long key3, short value3, long key4, short value4)
-
withoutKey
public LongShortHashMap withoutKey(long key)
Description copied from interface:MutableLongShortMapRemoves the mapping associated with the key, if one exists, from this map.- Specified by:
withoutKeyin interfaceMutableLongShortMap- Parameters:
key- the key to remove- Returns:
- this map
- See Also:
MutableLongShortMap.remove(long)
-
withoutAllKeys
public LongShortHashMap withoutAllKeys(LongIterable keys)
Description copied from interface:MutableLongShortMapRemoves the mappings associated with all the keys, if they exist, from this map.- Specified by:
withoutAllKeysin interfaceMutableLongShortMap- Parameters:
keys- the keys to remove- Returns:
- this map
- See Also:
MutableLongShortMap.remove(long)
-
asUnmodifiable
public MutableLongShortMap asUnmodifiable()
Description copied from interface:MutableLongShortMapReturns an unmodifiable view of this map, delegating all read-only operations to this map and throwing anUnsupportedOperationExceptionfor all mutating operations. This avoids the overhead of copying the map when callingLongShortMap.toImmutable()while still providing immutability.- Specified by:
asUnmodifiablein interfaceMutableLongShortMap- Returns:
- an unmodifiable view of this map
-
asSynchronized
public MutableLongShortMap asSynchronized()
Description copied from interface:MutableLongShortMapReturns a synchronized view of this map, delegating all operations to this map but ensuring only one caller has access to the map at a time.- Specified by:
asSynchronizedin interfaceMutableLongShortMap- Returns:
- a synchronized view of this map
-
toImmutable
public ImmutableLongShortMap toImmutable()
Description copied from interface:LongShortMapReturns a copy of this map that is immutable (if this map is mutable) or itself if it is already immutable.- Specified by:
toImmutablein interfaceLongShortMap- Returns:
- an immutable map that is equivalent to this one
-
get
public short get(long key)
Description copied from interface:LongShortMapRetrieves the value associated with the key. If no mapping exists for the key, the default value (usually0) is returned.- Specified by:
getin interfaceLongShortMap- Parameters:
key- the key- Returns:
- the value associated with the key, or the default value if no such mapping exists
-
getIfAbsent
public short getIfAbsent(long key, short ifAbsent)Description copied from interface:LongShortMapRetrieves the value associated with the key, returning the specified default value if no such mapping exists.- Specified by:
getIfAbsentin interfaceLongShortMap- Parameters:
key- the keyifAbsent- the default value to return if no mapping exists forkey- Returns:
- the value associated with the key, or
ifAbsentif no such mapping exists.
-
getForSentinel
private short getForSentinel(long key, short ifAbsent)
-
slowGetIfAbsent
private short slowGetIfAbsent(long key, short ifAbsent)
-
fastGetIfAbsent
private short fastGetIfAbsent(long key, short ifAbsent)
-
slowGetIfAbsentTwo
private short slowGetIfAbsentTwo(long key, short ifAbsent)
-
getOrThrow
public short getOrThrow(long key)
Description copied from interface:LongShortMapRetrieves the value associated with the key, throwing anIllegalStateExceptionif no such mapping exists.- Specified by:
getOrThrowin interfaceLongShortMap- Parameters:
key- the key- Returns:
- the value associated with the key
-
containsKey
public boolean containsKey(long key)
Description copied from interface:LongShortMapReturns whether or not the key is present in the map.- Specified by:
containsKeyin interfaceLongKeysMap- Specified by:
containsKeyin interfaceLongShortMap- Parameters:
key- the key- Returns:
- if a mapping exists in this map for the key
-
forEachKey
public void forEachKey(LongProcedure procedure)
Description copied from interface:LongShortMapIterates through each key in the map, invoking the procedure for each.- Specified by:
forEachKeyin interfaceLongKeysMap- Specified by:
forEachKeyin interfaceLongShortMap- Parameters:
procedure- the procedure to invoke for each key
-
forEachKeyValue
public void forEachKeyValue(LongShortProcedure procedure)
Description copied from interface:LongShortMapIterates through each key/value pair in the map, invoking the procedure for each.- Specified by:
forEachKeyValuein interfaceLongShortMap- Parameters:
procedure- the procedure to invoke for each key/value pair
-
allSatisfyKeyValue
public boolean allSatisfyKeyValue(LongShortPredicate predicate)
- Specified by:
allSatisfyKeyValuein interfaceLongShortMap- Since:
- 12.0
-
keysView
public LazyLongIterable keysView()
Description copied from interface:LongShortMapReturns a view of the keys in this map. This iterable is backed by the map, so any modifications to the underlying map will be reflected in the keys returned by the iterable.- Specified by:
keysViewin interfaceLongShortMap- Returns:
- a view of the keys in this map
-
keyValuesView
public RichIterable<LongShortPair> keyValuesView()
Description copied from interface:LongShortMapReturns a view of the key/value pairs in this map. This iterable is backed by the map, so any modifications to the underlying map will be reflected in the pairs returned by the iterable.- Specified by:
keyValuesViewin interfaceLongShortMap- Returns:
- a view of the keys in this map
-
flipUniqueValues
public MutableShortLongMap flipUniqueValues()
Description copied from interface:LongShortMapReturn the ShortLongMap that is obtained by flipping the direction of this map and making the associations from value to key.- Specified by:
flipUniqueValuesin interfaceLongShortMap- Specified by:
flipUniqueValuesin interfaceMutableLongShortMap
-
select
public LongShortHashMap select(LongShortPredicate predicate)
Description copied from interface:LongShortMapReturn a copy of this map containing only the key/value pairs that match the predicate.- Specified by:
selectin interfaceLongShortMap- Specified by:
selectin interfaceMutableLongShortMap- Parameters:
predicate- the predicate to determine which key/value pairs in this map should be included in the returned map- Returns:
- a copy of this map with the matching key/value pairs
-
reject
public LongShortHashMap reject(LongShortPredicate predicate)
Description copied from interface:LongShortMapReturn a copy of this map containing only the key/value pairs that do not match the predicate.- Specified by:
rejectin interfaceLongShortMap- Specified by:
rejectin interfaceMutableLongShortMap- Parameters:
predicate- the predicate to determine which key/value pairs in this map should be excluded from the returned map- Returns:
- a copy of this map without the matching key/value pairs
-
writeExternal
public void writeExternal(java.io.ObjectOutput out) throws java.io.IOException- Specified by:
writeExternalin interfacejava.io.Externalizable- Throws:
java.io.IOException
-
readExternal
public void readExternal(java.io.ObjectInput in) throws java.io.IOException, java.lang.ClassNotFoundException- Specified by:
readExternalin interfacejava.io.Externalizable- Throws:
java.io.IOExceptionjava.lang.ClassNotFoundException
-
trimToSize
public boolean trimToSize()
- Since:
- 12.0
-
compact
@Deprecated public void compact()
Deprecated.since 12.0 - UsetrimToSize()insteadRehashes every element in the set into a new backing table of the smallest possible size and eliminating removed sentinels.
-
rehashAndGrow
private void rehashAndGrow()
-
rehash
private void rehash(int newCapacity)
-
probe
int probe(long element)
-
probeTwo
int probeTwo(long element, int removedIndex)
-
probeThree
int probeThree(long element, int removedIndex)
-
spreadAndMask
int spreadAndMask(long element)
-
spreadTwoAndMask
int spreadTwoAndMask(long element)
-
mask
private int mask(int spread)
-
allocateTable
protected void allocateTable(int sizeToAllocate)
-
isEmptyKey
private static boolean isEmptyKey(long key)
-
isRemovedKey
private static boolean isRemovedKey(long key)
-
isNonSentinel
private static boolean isNonSentinel(long key)
-
isNonSentinelAtIndex
protected boolean isNonSentinelAtIndex(int index)
- Specified by:
isNonSentinelAtIndexin classAbstractMutableShortValuesMap
-
maxOccupiedWithData
private int maxOccupiedWithData()
-
keySet
public MutableLongSet keySet()
Description copied from interface:LongShortMapReturns a set containing all the keys in this map. The set is backed by the map, so any modifications to the returned set will affect this map.- Specified by:
keySetin interfaceLongShortMap- Returns:
- a mutable set containing the keys in this map
-
values
public MutableShortCollection values()
Description copied from interface:ShortValuesMapReturns the values in this map as a separate collection. The returned collection is backed by the map, so any changes made to the returned collection will affect the state of this map.- Specified by:
valuesin interfaceShortValuesMap- Returns:
- the values as a collection backed by this map
-
-