Class IntDoubleHashMap
- java.lang.Object
-
- org.eclipse.collections.impl.primitive.AbstractDoubleIterable
-
- org.eclipse.collections.impl.map.mutable.primitive.AbstractMutableDoubleValuesMap
-
- org.eclipse.collections.impl.map.mutable.primitive.IntDoubleHashMap
-
- All Implemented Interfaces:
java.io.Externalizable,java.io.Serializable,DoubleIterable,DoubleValuesMap,IntDoubleMap,MutableDoubleValuesMap,MutableIntDoubleMap,PrimitiveIterable,MutableIntKeysMap,IntKeysMap
public class IntDoubleHashMap extends AbstractMutableDoubleValuesMap implements MutableIntDoubleMap, java.io.Externalizable, MutableIntKeysMap
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 classIntDoubleHashMap.InternalDoubleIteratorprivate classIntDoubleHashMap.KeySetprivate classIntDoubleHashMap.KeySetIteratorprivate classIntDoubleHashMap.KeysViewprivate classIntDoubleHashMap.KeyValuesViewprivate classIntDoubleHashMap.ValuesCollection-
Nested classes/interfaces inherited from class org.eclipse.collections.impl.map.mutable.primitive.AbstractMutableDoubleValuesMap
AbstractMutableDoubleValuesMap.AbstractDoubleValuesCollection, AbstractMutableDoubleValuesMap.SentinelValues
-
-
Field Summary
Fields Modifier and Type Field Description private static intCACHE_LINE_SIZEprivate booleancopyKeysOnWriteprivate static intDEFAULT_INITIAL_CAPACITYprivate static intEMPTY_KEYprivate static doubleEMPTY_VALUEprivate static intINITIAL_LINEAR_PROBEprivate static intKEY_SIZEprivate int[]keysprivate intoccupiedWithDataprivate intoccupiedWithSentinelsprivate static intREMOVED_KEYprivate AbstractMutableDoubleValuesMap.SentinelValuessentinelValuesprivate static longserialVersionUIDprivate double[]values
-
Constructor Summary
Constructors Constructor Description IntDoubleHashMap()IntDoubleHashMap(int initialCapacity)IntDoubleHashMap(IntDoubleMap map)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description private voidaddKeyValueAtIndex(int key, double value, int index)doubleaddToValue(int key, double 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(IntDoublePredicate predicate)MutableIntDoubleMapasSynchronized()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.MutableIntDoubleMapasUnmodifiable()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(int key)Returns whether or not the key is present in the map.private voidcopyKeys()MutableDoubleIteratordoubleIterator()Returns a primitive iterator that can be used to iterate over the DoubleIterable in an imperative style.booleanequals(java.lang.Object obj)Follows the same general contract asMap.equals(Object).private doublefastGetIfAbsent(int key, double ifAbsent)MutableDoubleIntMapflipUniqueValues()Return the DoubleIntMap that is obtained by flipping the direction of this map and making the associations from value to key.voidforEachKey(IntProcedure procedure)Iterates through each key in the map, invoking the procedure for each.voidforEachKeyValue(IntDoubleProcedure procedure)Iterates through each key/value pair in the map, invoking the procedure for each.doubleget(int key)Retrieves the value associated with the key.doublegetAndPut(int key, double putValue, double defaultValue)Retrieves the value associated with the key if one exists; associates a putValue with the key.protected doublegetEmptyValue()private doublegetForSentinel(int key, double ifAbsent)doublegetIfAbsent(int key, double ifAbsent)Retrieves the value associated with the key, returning the specified default value if no such mapping exists.doublegetIfAbsentPut(int key, double value)Retrieves the value associated with the key if one exists; if it does not, associates a value with the key.doublegetIfAbsentPut(int key, DoubleFunction0 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> doublegetIfAbsentPutWith(int key, DoubleFunction<? 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.doublegetIfAbsentPutWithKey(int key, IntToDoubleFunction 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()doublegetOrThrow(int key)Retrieves the value associated with the key, throwing anIllegalStateExceptionif no such mapping exists.protected AbstractMutableDoubleValuesMap.SentinelValuesgetSentinelValues()protected intgetTableSize()protected doublegetValueAtIndex(int index)inthashCode()Follows the same general contract asMap.hashCode().<V> VinjectInto(V injectedValue, ObjectDoubleToObjectFunction<? super V,? extends V> function)private static booleanisEmptyKey(int key)private static booleanisNonSentinel(int key)protected booleanisNonSentinelAtIndex(int index)private static booleanisRemovedKey(int key)MutableIntSetkeySet()Returns a set containing all the keys in this map.LazyIntIterablekeysView()Returns a view of the keys in this map.RichIterable<IntDoublePair>keyValuesView()Returns a view of the key/value pairs in this map.private intmask(int spread)private intmaxOccupiedWithData()static IntDoubleHashMapnewWithKeysValues(int key1, double value1)static IntDoubleHashMapnewWithKeysValues(int key1, double value1, int key2, double value2)static IntDoubleHashMapnewWithKeysValues(int key1, double value1, int key2, double value2, int key3, double value3)static IntDoubleHashMapnewWithKeysValues(int key1, double value1, int key2, double value2, int key3, double value3, int key4, double value4)(package private) intprobe(int element)(package private) intprobeThree(int element, int removedIndex)(package private) intprobeTwo(int element, int removedIndex)voidput(int key, double value)Associates a value with the specified key.voidputAll(IntDoubleMap map)Puts all of the key/value mappings from the specified map into this map.private voidputForEmptySentinel(double value)private voidputForRemovedSentinel(double value)voidreadExternal(java.io.ObjectInput in)private voidrehash(int newCapacity)private voidrehashAndGrow()IntDoubleHashMapreject(IntDoublePredicate predicate)Return a copy of this map containing only the key/value pairs that do not match the predicate.voidremove(int key)Removes the mapping associated with the key, if one exists, from the map.voidremoveKey(int key)Removes the mapping associated with the key, if one exists, from the map.private voidremoveKeyAtIndex(int index)doubleremoveKeyIfAbsent(int key, double value)Removes the mapping associated with the key, if one exists, from the map, returning the previously associated value with the key.IntDoubleHashMapselect(IntDoublePredicate predicate)Return a copy of this map containing only the key/value pairs that match the predicate.protected voidsetSentinelValuesNull()private doubleslowGetIfAbsent(int key, double ifAbsent)private doubleslowGetIfAbsentTwo(int key, double ifAbsent)private intsmallestPowerOfTwoGreaterThan(int n)(package private) intspreadAndMask(int element)(package private) intspreadTwoAndMask(int element)ImmutableIntDoubleMaptoImmutable()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()doubleupdateValue(int key, double initialValueIfAbsent, DoubleToDoubleFunction 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(IntDoubleToDoubleFunction function)Updates the values in-place.MutableDoubleCollectionvalues()Returns the values in this map as a separate collection.IntDoubleHashMapwithKeysValues(int key1, double value1, int key2, double value2)IntDoubleHashMapwithKeysValues(int key1, double value1, int key2, double value2, int key3, double value3)IntDoubleHashMapwithKeysValues(int key1, double value1, int key2, double value2, int key3, double value3, int key4, double value4)IntDoubleHashMapwithKeyValue(int key1, double value1)Associates a value with the specified key.IntDoubleHashMapwithoutAllKeys(IntIterable keys)Removes the mappings associated with all the keys, if they exist, from this map.IntDoubleHashMapwithoutKey(int 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.AbstractMutableDoubleValuesMap
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.AbstractDoubleIterable
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.api.DoubleIterable
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.DoubleValuesMap
containsValue, forEachValue, tap
-
Methods inherited from interface org.eclipse.collections.api.map.primitive.IntDoubleMap
injectIntoKeyValue
-
Methods inherited from interface org.eclipse.collections.impl.map.primitive.IntKeysMap
isEmpty, notEmpty, size
-
Methods inherited from interface org.eclipse.collections.api.map.primitive.MutableDoubleValuesMap
collect, reject, select
-
Methods inherited from interface org.eclipse.collections.api.map.primitive.MutableIntDoubleMap
putPair, withAllKeyValues
-
Methods inherited from interface org.eclipse.collections.api.PrimitiveIterable
appendString, appendString, appendString, isEmpty, makeString, makeString, makeString, notEmpty, size
-
-
-
-
Field Detail
-
EMPTY_VALUE
private static final double EMPTY_VALUE
- See Also:
- Constant Field Values
-
serialVersionUID
private static final long serialVersionUID
- See Also:
- Constant Field Values
-
EMPTY_KEY
private static final int EMPTY_KEY
- See Also:
- Constant Field Values
-
REMOVED_KEY
private static final int 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 int[] keys
-
values
private double[] values
-
occupiedWithData
private int occupiedWithData
-
occupiedWithSentinels
private int occupiedWithSentinels
-
sentinelValues
private AbstractMutableDoubleValuesMap.SentinelValues sentinelValues
-
copyKeysOnWrite
private boolean copyKeysOnWrite
-
-
Constructor Detail
-
IntDoubleHashMap
public IntDoubleHashMap()
-
IntDoubleHashMap
public IntDoubleHashMap(int initialCapacity)
-
IntDoubleHashMap
public IntDoubleHashMap(IntDoubleMap map)
-
-
Method Detail
-
newWithKeysValues
public static IntDoubleHashMap newWithKeysValues(int key1, double value1)
-
newWithKeysValues
public static IntDoubleHashMap newWithKeysValues(int key1, double value1, int key2, double value2)
-
newWithKeysValues
public static IntDoubleHashMap newWithKeysValues(int key1, double value1, int key2, double value2, int key3, double value3)
-
newWithKeysValues
public static IntDoubleHashMap newWithKeysValues(int key1, double value1, int key2, double value2, int key3, double value3, int key4, double value4)
-
smallestPowerOfTwoGreaterThan
private int smallestPowerOfTwoGreaterThan(int n)
-
getOccupiedWithData
protected int getOccupiedWithData()
- Specified by:
getOccupiedWithDatain classAbstractMutableDoubleValuesMap
-
getSentinelValues
protected AbstractMutableDoubleValuesMap.SentinelValues getSentinelValues()
- Specified by:
getSentinelValuesin classAbstractMutableDoubleValuesMap
-
setSentinelValuesNull
protected void setSentinelValuesNull()
- Specified by:
setSentinelValuesNullin classAbstractMutableDoubleValuesMap
-
getEmptyValue
protected double getEmptyValue()
- Specified by:
getEmptyValuein classAbstractMutableDoubleValuesMap
-
getTableSize
protected int getTableSize()
- Specified by:
getTableSizein classAbstractMutableDoubleValuesMap
-
getValueAtIndex
protected double getValueAtIndex(int index)
- Specified by:
getValueAtIndexin classAbstractMutableDoubleValuesMap
-
equals
public boolean equals(java.lang.Object obj)
Description copied from interface:IntDoubleMapFollows the same general contract asMap.equals(Object).- Specified by:
equalsin interfaceIntDoubleMap- Overrides:
equalsin classjava.lang.Object
-
hashCode
public int hashCode()
Description copied from interface:IntDoubleMapFollows the same general contract asMap.hashCode().- Specified by:
hashCodein interfaceIntDoubleMap- 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 interfaceIntDoubleMap- Specified by:
toStringin interfacePrimitiveIterable- Overrides:
toStringin classAbstractDoubleIterable- Returns:
- a string representation of this PrimitiveIterable
- See Also:
AbstractCollection.toString()
-
doubleIterator
public MutableDoubleIterator doubleIterator()
Description copied from interface:DoubleIterableReturns a primitive iterator that can be used to iterate over the DoubleIterable in an imperative style.- Specified by:
doubleIteratorin interfaceDoubleIterable- Specified by:
doubleIteratorin interfaceMutableDoubleValuesMap
-
injectInto
public <V> V injectInto(V injectedValue, ObjectDoubleToObjectFunction<? super V,? extends V> function)- Specified by:
injectIntoin interfaceDoubleIterable
-
clear
public void clear()
Description copied from interface:MutableDoubleValuesMapRemoves all entries from this map.- Specified by:
clearin interfaceMutableDoubleValuesMap- Specified by:
clearin interfaceMutableIntKeysMap
-
put
public void put(int key, double value)Description copied from interface:MutableIntDoubleMapAssociates 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 interfaceMutableIntDoubleMap- Parameters:
key- the keyvalue- the value to associate withvalue
-
putForRemovedSentinel
private void putForRemovedSentinel(double value)
-
putForEmptySentinel
private void putForEmptySentinel(double value)
-
putAll
public void putAll(IntDoubleMap map)
Description copied from interface:MutableIntDoubleMapPuts 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 interfaceMutableIntDoubleMap- Parameters:
map- the map to copy into this map
-
updateValues
public void updateValues(IntDoubleToDoubleFunction function)
Description copied from interface:MutableIntDoubleMapUpdates the values in-place.- Specified by:
updateValuesin interfaceMutableIntDoubleMap- Parameters:
function- that takes a key and its value and that returns a new value for this key
-
removeKey
public void removeKey(int key)
Description copied from interface:MutableIntDoubleMapRemoves the mapping associated with the key, if one exists, from the map.- Specified by:
removeKeyin interfaceMutableIntDoubleMap- Specified by:
removeKeyin interfaceMutableIntKeysMap- Parameters:
key- the key to remove- See Also:
MutableIntDoubleMap.remove(int)
-
remove
public void remove(int key)
Description copied from interface:MutableIntDoubleMapRemoves the mapping associated with the key, if one exists, from the map.- Specified by:
removein interfaceMutableIntDoubleMap- Parameters:
key- the key to remove- See Also:
MutableIntDoubleMap.removeKey(int)
-
removeKeyIfAbsent
public double removeKeyIfAbsent(int key, double value)Description copied from interface:MutableIntDoubleMapRemoves 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 interfaceMutableIntDoubleMap- 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 double getIfAbsentPut(int key, double value)Description copied from interface:MutableIntDoubleMapRetrieves the value associated with the key if one exists; if it does not, associates a value with the key.- Specified by:
getIfAbsentPutin interfaceMutableIntDoubleMap- 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 double getAndPut(int key, double putValue, double defaultValue)Description copied from interface:MutableIntDoubleMapRetrieves the value associated with the key if one exists; associates a putValue with the key.- Specified by:
getAndPutin interfaceMutableIntDoubleMap- 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 double getIfAbsentPut(int key, DoubleFunction0 function)Description copied from interface:MutableIntDoubleMapRetrieves 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 interfaceMutableIntDoubleMap- 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> double getIfAbsentPutWith(int key, DoubleFunction<? super P> function, P parameter)Description copied from interface:MutableIntDoubleMapRetrieves 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 interfaceMutableIntDoubleMap- 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 double getIfAbsentPutWithKey(int key, IntToDoubleFunction function)Description copied from interface:MutableIntDoubleMapRetrieves 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 interfaceMutableIntDoubleMap- 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 double addToValue(int key, double toBeAdded)Description copied from interface:MutableIntDoubleMapIncrements 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 interfaceMutableIntDoubleMap- 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(int key, double value, int index)
-
removeKeyAtIndex
private void removeKeyAtIndex(int index)
-
copyKeys
private void copyKeys()
-
updateValue
public double updateValue(int key, double initialValueIfAbsent, DoubleToDoubleFunction function)Description copied from interface:MutableIntDoubleMapUpdates 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 interfaceMutableIntDoubleMap- 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 IntDoubleHashMap withKeyValue(int key1, double value1)
Description copied from interface:MutableIntDoubleMapAssociates 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 interfaceMutableIntDoubleMap- Parameters:
key1- the keyvalue1- the value to associate withvalue- Returns:
- this map
- See Also:
MutableIntDoubleMap.put(int, double)
-
withKeysValues
public IntDoubleHashMap withKeysValues(int key1, double value1, int key2, double value2)
-
withKeysValues
public IntDoubleHashMap withKeysValues(int key1, double value1, int key2, double value2, int key3, double value3)
-
withKeysValues
public IntDoubleHashMap withKeysValues(int key1, double value1, int key2, double value2, int key3, double value3, int key4, double value4)
-
withoutKey
public IntDoubleHashMap withoutKey(int key)
Description copied from interface:MutableIntDoubleMapRemoves the mapping associated with the key, if one exists, from this map.- Specified by:
withoutKeyin interfaceMutableIntDoubleMap- Parameters:
key- the key to remove- Returns:
- this map
- See Also:
MutableIntDoubleMap.remove(int)
-
withoutAllKeys
public IntDoubleHashMap withoutAllKeys(IntIterable keys)
Description copied from interface:MutableIntDoubleMapRemoves the mappings associated with all the keys, if they exist, from this map.- Specified by:
withoutAllKeysin interfaceMutableIntDoubleMap- Parameters:
keys- the keys to remove- Returns:
- this map
- See Also:
MutableIntDoubleMap.remove(int)
-
asUnmodifiable
public MutableIntDoubleMap asUnmodifiable()
Description copied from interface:MutableIntDoubleMapReturns 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 callingIntDoubleMap.toImmutable()while still providing immutability.- Specified by:
asUnmodifiablein interfaceMutableIntDoubleMap- Returns:
- an unmodifiable view of this map
-
asSynchronized
public MutableIntDoubleMap asSynchronized()
Description copied from interface:MutableIntDoubleMapReturns 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 interfaceMutableIntDoubleMap- Returns:
- a synchronized view of this map
-
toImmutable
public ImmutableIntDoubleMap toImmutable()
Description copied from interface:IntDoubleMapReturns a copy of this map that is immutable (if this map is mutable) or itself if it is already immutable.- Specified by:
toImmutablein interfaceIntDoubleMap- Returns:
- an immutable map that is equivalent to this one
-
get
public double get(int key)
Description copied from interface:IntDoubleMapRetrieves the value associated with the key. If no mapping exists for the key, the default value (usually0) is returned.- Specified by:
getin interfaceIntDoubleMap- Parameters:
key- the key- Returns:
- the value associated with the key, or the default value if no such mapping exists
-
getIfAbsent
public double getIfAbsent(int key, double ifAbsent)Description copied from interface:IntDoubleMapRetrieves the value associated with the key, returning the specified default value if no such mapping exists.- Specified by:
getIfAbsentin interfaceIntDoubleMap- 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 double getForSentinel(int key, double ifAbsent)
-
slowGetIfAbsent
private double slowGetIfAbsent(int key, double ifAbsent)
-
fastGetIfAbsent
private double fastGetIfAbsent(int key, double ifAbsent)
-
slowGetIfAbsentTwo
private double slowGetIfAbsentTwo(int key, double ifAbsent)
-
getOrThrow
public double getOrThrow(int key)
Description copied from interface:IntDoubleMapRetrieves the value associated with the key, throwing anIllegalStateExceptionif no such mapping exists.- Specified by:
getOrThrowin interfaceIntDoubleMap- Parameters:
key- the key- Returns:
- the value associated with the key
-
containsKey
public boolean containsKey(int key)
Description copied from interface:IntDoubleMapReturns whether or not the key is present in the map.- Specified by:
containsKeyin interfaceIntDoubleMap- Specified by:
containsKeyin interfaceIntKeysMap- Parameters:
key- the key- Returns:
- if a mapping exists in this map for the key
-
forEachKey
public void forEachKey(IntProcedure procedure)
Description copied from interface:IntDoubleMapIterates through each key in the map, invoking the procedure for each.- Specified by:
forEachKeyin interfaceIntDoubleMap- Specified by:
forEachKeyin interfaceIntKeysMap- Parameters:
procedure- the procedure to invoke for each key
-
forEachKeyValue
public void forEachKeyValue(IntDoubleProcedure procedure)
Description copied from interface:IntDoubleMapIterates through each key/value pair in the map, invoking the procedure for each.- Specified by:
forEachKeyValuein interfaceIntDoubleMap- Parameters:
procedure- the procedure to invoke for each key/value pair
-
allSatisfyKeyValue
public boolean allSatisfyKeyValue(IntDoublePredicate predicate)
- Specified by:
allSatisfyKeyValuein interfaceIntDoubleMap- Since:
- 12.0
-
keysView
public LazyIntIterable keysView()
Description copied from interface:IntDoubleMapReturns 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 interfaceIntDoubleMap- Returns:
- a view of the keys in this map
-
keyValuesView
public RichIterable<IntDoublePair> keyValuesView()
Description copied from interface:IntDoubleMapReturns 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 interfaceIntDoubleMap- Returns:
- a view of the keys in this map
-
flipUniqueValues
public MutableDoubleIntMap flipUniqueValues()
Description copied from interface:IntDoubleMapReturn the DoubleIntMap that is obtained by flipping the direction of this map and making the associations from value to key.- Specified by:
flipUniqueValuesin interfaceIntDoubleMap- Specified by:
flipUniqueValuesin interfaceMutableIntDoubleMap
-
select
public IntDoubleHashMap select(IntDoublePredicate predicate)
Description copied from interface:IntDoubleMapReturn a copy of this map containing only the key/value pairs that match the predicate.- Specified by:
selectin interfaceIntDoubleMap- Specified by:
selectin interfaceMutableIntDoubleMap- 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 IntDoubleHashMap reject(IntDoublePredicate predicate)
Description copied from interface:IntDoubleMapReturn a copy of this map containing only the key/value pairs that do not match the predicate.- Specified by:
rejectin interfaceIntDoubleMap- Specified by:
rejectin interfaceMutableIntDoubleMap- 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(int element)
-
probeTwo
int probeTwo(int element, int removedIndex)
-
probeThree
int probeThree(int element, int removedIndex)
-
spreadAndMask
int spreadAndMask(int element)
-
spreadTwoAndMask
int spreadTwoAndMask(int element)
-
mask
private int mask(int spread)
-
allocateTable
protected void allocateTable(int sizeToAllocate)
-
isEmptyKey
private static boolean isEmptyKey(int key)
-
isRemovedKey
private static boolean isRemovedKey(int key)
-
isNonSentinel
private static boolean isNonSentinel(int key)
-
isNonSentinelAtIndex
protected boolean isNonSentinelAtIndex(int index)
- Specified by:
isNonSentinelAtIndexin classAbstractMutableDoubleValuesMap
-
maxOccupiedWithData
private int maxOccupiedWithData()
-
keySet
public MutableIntSet keySet()
Description copied from interface:IntDoubleMapReturns 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 interfaceIntDoubleMap- Returns:
- a mutable set containing the keys in this map
-
values
public MutableDoubleCollection values()
Description copied from interface:DoubleValuesMapReturns 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 interfaceDoubleValuesMap- Returns:
- the values as a collection backed by this map
-
-