Modul speiger.src.collections
Klasse Long2ObjectOpenCustomHashMap<V>
java.lang.Object
java.util.AbstractMap<Long,V>
speiger.src.collections.longs.maps.abstracts.AbstractLong2ObjectMap<V>
speiger.src.collections.longs.maps.impl.customHash.Long2ObjectOpenCustomHashMap<V>
- Typparameter:
V- the keyType of elements maintained by this Collection
- Alle implementierten Schnittstellen:
LongFunction<V>,Map<Long,,V> LongFunction<V>,Long2ObjectMap<V>,ITrimmable
- Bekannte direkte Unterklassen:
Long2ObjectLinkedOpenCustomHashMap
public class Long2ObjectOpenCustomHashMap<V>
extends AbstractLong2ObjectMap<V>
implements ITrimmable
A Type Specific HashMap that allows for custom HashControl.
For cases where Objects/primitive do not allow hashcoding this can be really useful and provide a lot of control.
-
Verschachtelte Klassen - Übersicht
Von Klasse geerbte verschachtelte Klassen/Schnittstellen speiger.src.collections.longs.maps.abstracts.AbstractLong2ObjectMap
AbstractLong2ObjectMap.BasicEntry<V>Von Klasse geerbte verschachtelte Klassen/Schnittstellen java.util.AbstractMap
AbstractMap.SimpleEntry<K,V>, AbstractMap.SimpleImmutableEntry<K, V> Von Schnittstelle geerbte verschachtelte Klassen/Schnittstellen speiger.src.collections.longs.maps.interfaces.Long2ObjectMap
Long2ObjectMap.BuilderCache<V>, Long2ObjectMap.Entry<V>, Long2ObjectMap.FastEntrySet<V>, Long2ObjectMap.MapBuilder -
Konstruktorübersicht
KonstruktorenKonstruktorBeschreibungLong2ObjectOpenCustomHashMap(int minCapacity, float loadFactor, LongStrategy strategy) Constructor that defines the minimum capacity and load factorLong2ObjectOpenCustomHashMap(int minCapacity, LongStrategy strategy) Constructor that defines the minimum capacityLong2ObjectOpenCustomHashMap(long[] keys, V[] values, float loadFactor, LongStrategy strategy) Helper constructor that allow to create a map from unboxed valuesLong2ObjectOpenCustomHashMap(long[] keys, V[] values, LongStrategy strategy) Helper constructor that allow to create a map from unboxed valuesLong2ObjectOpenCustomHashMap(Long[] keys, V[] values, float loadFactor, LongStrategy strategy) Helper constructor that allow to create a map from boxed values (it will unbox them)Long2ObjectOpenCustomHashMap(Long[] keys, V[] values, LongStrategy strategy) Helper constructor that allow to create a map from boxed values (it will unbox them)Long2ObjectOpenCustomHashMap(Map<? extends Long, ? extends V> map, float loadFactor, LongStrategy strategy) A Helper constructor that allows to create a Map with exactly the same values as the provided map.Long2ObjectOpenCustomHashMap(Map<? extends Long, ? extends V> map, LongStrategy strategy) A Helper constructor that allows to create a Map with exactly the same values as the provided map.Long2ObjectOpenCustomHashMap(Long2ObjectMap<V> map, float loadFactor, LongStrategy strategy) A Type Specific Helper function that allows to create a new Map with exactly the same values as the provided map.Long2ObjectOpenCustomHashMap(Long2ObjectMap<V> map, LongStrategy strategy) A Type Specific Helper function that allows to create a new Map with exactly the same values as the provided map.Long2ObjectOpenCustomHashMap(LongStrategy strategy) Default Contstructor -
Methodenübersicht
Modifizierer und TypMethodeBeschreibungvoidclear()voidclearAndTrim(int size) Trims the collection down to the requested size and clears all elements while doing socompute(long key, LongObjectUnaryOperator<V> mappingFunction) A Type Specific compute method to reduce boxing/unboxing If the generated value equals the getDefaultReturnValue it will simply not insert it since that is treated as "null".computeIfAbsent(long key, LongFunction<V> mappingFunction) A Type Specific computeIfAbsent method to reduce boxing/unboxing If the generated value equals the getDefaultReturnValue it will simply not insert it since that is treated as "null".computeIfPresent(long key, LongObjectUnaryOperator<V> mappingFunction) A Type Specific compute method to reduce boxing/unboxing If the generated value equals the getDefaultReturnValue it will simply not insert it since that is treated as "null".booleancontainsKey(long key) Type Specific method to reduce boxing/unboxing of valuesbooleancontainsKey(Object key) Veraltet.booleancontainsValue(Object value) copy()A Function that does a shallow clone of the Map itself.voidforEach(LongObjectConsumer<V> action) Type Specific forEach method to reduce boxing/unboxingget(long key) A Type Specific get method to reduce boxing/unboxinggetOrDefault(long key, V defaultValue) A Type Specific getOrDefault method to reduce boxing/unboxingkeySet()Type Sensitive EntrySet to reduce boxing/unboxing and optionally Temp Object Allocation.merge(long key, V value, ObjectObjectUnaryOperator<V, V> mappingFunction) A Type Specific merge method to reduce boxing/unboxing If the generated value equals the getDefaultReturnValue it will simply not insert it since that is treated as "null".voidmergeAll(Long2ObjectMap<V> m, ObjectObjectUnaryOperator<V, V> mappingFunction) A Bulk method for merging Maps.Type Specific method to reduce boxing/unboxing of valuesputIfAbsent(long key, V value) Type Specific method to reduce boxing/unboxing of valuesremove(long key) Type Specific remove function to reduce boxing/unboxingbooleanType Specific remove function to reduce boxing/unboxingbooleanremoveOrDefault(long key, V defaultValue) Type-Specific Remove function with a default return value if wanted.A Type Specific replace method to reduce boxing/unboxing replace an existing valuebooleanA Type Specific replace method to replace an existing valueintsize()supplyIfAbsent(long key, ObjectSupplier<V> valueProvider) A Supplier based computeIfAbsent function to fill the most used usecase of this function If the generated value equals the getDefaultReturnValue it will simply not insert it since that is treated as "null".booleantrim(int size) Trims the original collection down to the size of the current elements or the requested size depending which is biggervalues()Von Klasse geerbte Methoden speiger.src.collections.longs.maps.abstracts.AbstractLong2ObjectMap
entrySet, equals, getDefaultReturnValue, getOrDefault, hashCode, put, putAll, putAll, putAll, putAll, putAllIfAbsent, replaceObjects, replaceObjects, setDefaultReturnValueVon Klasse geerbte Methoden java.util.AbstractMap
isEmpty, toStringVon Schnittstelle geerbte Methoden speiger.src.collections.utils.ITrimmable
clearAndTrim, trimVon Schnittstelle geerbte Methoden speiger.src.collections.longs.maps.interfaces.Long2ObjectMap
apply, compute, computeIfAbsent, computeIfPresent, forEach, merge, put, put, putAll, putAll, putIfAbsent, replace, replace, replaceAll, synchronize, synchronize, unmodifiable
-
Konstruktordetails
-
Long2ObjectOpenCustomHashMap
Default Contstructor- Parameter:
strategy- the strategy that allows hash control.- Löst aus:
NullPointerException- if Strategy is null
-
Long2ObjectOpenCustomHashMap
Constructor that defines the minimum capacity- Parameter:
minCapacity- the minimum capacity the HashMap is allowed to be.strategy- the strategy that allows hash control.- Löst aus:
NullPointerException- if Strategy is nullIllegalStateException- if the minimum capacity is negative
-
Long2ObjectOpenCustomHashMap
Constructor that defines the minimum capacity and load factor- Parameter:
minCapacity- the minimum capacity the HashMap is allowed to be.loadFactor- the percentage of how full the backing array can be before they resizestrategy- the strategy that allows hash control.- Löst aus:
NullPointerException- if Strategy is nullIllegalStateException- if the minimum capacity is negativeIllegalStateException- if the loadfactor is either below/equal to 0 or above/equal to 1
-
Long2ObjectOpenCustomHashMap
Helper constructor that allow to create a map from boxed values (it will unbox them)- Parameter:
keys- the keys that should be put into the mapvalues- the values that should be put into the map.strategy- the strategy that allows hash control.- Löst aus:
NullPointerException- if Strategy is nullIllegalStateException- if the keys and values do not match in lenght
-
Long2ObjectOpenCustomHashMap
public Long2ObjectOpenCustomHashMap(Long[] keys, V[] values, float loadFactor, LongStrategy strategy) Helper constructor that allow to create a map from boxed values (it will unbox them)- Parameter:
keys- the keys that should be put into the mapvalues- the values that should be put into the map.loadFactor- the percentage of how full the backing array can be before they resizestrategy- the strategy that allows hash control.- Löst aus:
NullPointerException- if Strategy is nullIllegalStateException- if the keys and values do not match in lenghtIllegalStateException- if the loadfactor is either below/equal to 0 or above/equal to 1
-
Long2ObjectOpenCustomHashMap
Helper constructor that allow to create a map from unboxed values- Parameter:
keys- the keys that should be put into the mapvalues- the values that should be put into the map.strategy- the strategy that allows hash control.- Löst aus:
NullPointerException- if Strategy is nullIllegalStateException- if the keys and values do not match in lenght
-
Long2ObjectOpenCustomHashMap
public Long2ObjectOpenCustomHashMap(long[] keys, V[] values, float loadFactor, LongStrategy strategy) Helper constructor that allow to create a map from unboxed values- Parameter:
keys- the keys that should be put into the mapvalues- the values that should be put into the map.loadFactor- the percentage of how full the backing array can be before they resizestrategy- the strategy that allows hash control.- Löst aus:
NullPointerException- if Strategy is nullIllegalStateException- if the keys and values do not match in lenghtIllegalStateException- if the loadfactor is either below/equal to 0 or above/equal to 1
-
Long2ObjectOpenCustomHashMap
A Helper constructor that allows to create a Map with exactly the same values as the provided map.- Parameter:
map- the values that should be present in the mapstrategy- the strategy that allows hash control.- Löst aus:
NullPointerException- if Strategy is null
-
Long2ObjectOpenCustomHashMap
public Long2ObjectOpenCustomHashMap(Map<? extends Long, ? extends V> map, float loadFactor, LongStrategy strategy) A Helper constructor that allows to create a Map with exactly the same values as the provided map.- Parameter:
map- the values that should be present in the maploadFactor- the percentage of how full the backing array can be before they resizestrategy- the strategy that allows hash control.- Löst aus:
NullPointerException- if Strategy is nullIllegalStateException- if the loadfactor is either below/equal to 0 or above/equal to 1
-
Long2ObjectOpenCustomHashMap
A Type Specific Helper function that allows to create a new Map with exactly the same values as the provided map.- Parameter:
map- the values that should be present in the mapstrategy- the strategy that allows hash control.- Löst aus:
NullPointerException- if Strategy is null
-
Long2ObjectOpenCustomHashMap
A Type Specific Helper function that allows to create a new Map with exactly the same values as the provided map.- Parameter:
map- the values that should be present in the maploadFactor- the percentage of how full the backing array can be before they resizestrategy- the strategy that allows hash control.- Löst aus:
NullPointerException- if Strategy is nullIllegalStateException- if the loadfactor is either below/equal to 0 or above/equal to 1
-
-
Methodendetails
-
put
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapType Specific method to reduce boxing/unboxing of values- Angegeben von:
putin SchnittstelleLong2ObjectMap<V>- Parameter:
key- the key that should be inserted,value- the value that should be inserted- Gibt zurück:
- the last present value or default return value.
- Siehe auch:
-
putIfAbsent
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapType Specific method to reduce boxing/unboxing of values- Angegeben von:
putIfAbsentin SchnittstelleLong2ObjectMap<V>- Parameter:
key- the key that should be inserted,value- the value that should be inserted- Gibt zurück:
- the last present value or default return value.
- Siehe auch:
-
containsKey
public boolean containsKey(long key) Beschreibung aus Schnittstelle kopiert:Long2ObjectMapType Specific method to reduce boxing/unboxing of values- Angegeben von:
containsKeyin SchnittstelleLong2ObjectMap<V>- Setzt außer Kraft:
containsKeyin KlasseAbstractLong2ObjectMap<V>- Parameter:
key- element that is searched for- Gibt zurück:
- if the key is present
-
containsKey
Veraltet.- Angegeben von:
containsKeyin SchnittstelleLong2ObjectMap<V>- Angegeben von:
containsKeyin SchnittstelleMap<Long,V> - Setzt außer Kraft:
containsKeyin KlasseAbstractMap<Long,V> - Parameter:
key- that is searched for.- Gibt zurück:
- true if found
- Siehe auch:
-
containsValue
- Angegeben von:
containsValuein SchnittstelleMap<Long,V> - Setzt außer Kraft:
containsValuein KlasseAbstractLong2ObjectMap<V>
-
remove
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapType Specific remove function to reduce boxing/unboxing- Angegeben von:
removein SchnittstelleLong2ObjectMap<V>- Parameter:
key- the element that should be removed- Gibt zurück:
- the value that was removed or default return value
-
removeOrDefault
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapType-Specific Remove function with a default return value if wanted.- Angegeben von:
removeOrDefaultin SchnittstelleLong2ObjectMap<V>- Parameter:
key- the element that should be removeddefaultValue- the value that should be returned if the entry doesn't exist- Gibt zurück:
- the value that was removed or default value
- Siehe auch:
-
remove
- Angegeben von:
removein SchnittstelleLong2ObjectMap<V>- Angegeben von:
removein SchnittstelleMap<Long,V> - Setzt außer Kraft:
removein KlasseAbstractLong2ObjectMap<V>- Parameter:
key- the element that should be removed- Gibt zurück:
- the value that was removed or default return value
- Siehe auch:
-
remove
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapType Specific remove function to reduce boxing/unboxing- Angegeben von:
removein SchnittstelleLong2ObjectMap<V>- Parameter:
key- the element that should be removedvalue- the expected value that should be found- Gibt zurück:
- true if the key and value was found and removed
- Siehe auch:
-
remove
-
get
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapA Type Specific get method to reduce boxing/unboxing- Angegeben von:
getin SchnittstelleLong2ObjectMap<V>- Parameter:
key- the key that is searched for- Gibt zurück:
- the searched value or default return value
-
get
- Angegeben von:
getin SchnittstelleLong2ObjectMap<V>- Angegeben von:
getin SchnittstelleMap<Long,V> - Setzt außer Kraft:
getin KlasseAbstractLong2ObjectMap<V>
-
getOrDefault
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapA Type Specific getOrDefault method to reduce boxing/unboxing- Angegeben von:
getOrDefaultin SchnittstelleLong2ObjectMap<V>- Setzt außer Kraft:
getOrDefaultin KlasseAbstractLong2ObjectMap<V>- Parameter:
key- the key that is searched fordefaultValue- the value that should be returned if the key is not present- Gibt zurück:
- the searched value or defaultValue value
-
copy
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapA Function that does a shallow clone of the Map itself. This function is more optimized then a copy constructor since the Map does not have to be unsorted/resorted. It can be compared to Cloneable but with less exception risk- Angegeben von:
copyin SchnittstelleLong2ObjectMap<V>- Setzt außer Kraft:
copyin KlasseAbstractLong2ObjectMap<V>- Gibt zurück:
- a Shallow Copy of the Map
-
long2ObjectEntrySet
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapType Sensitive EntrySet to reduce boxing/unboxing and optionally Temp Object Allocation.- Angegeben von:
long2ObjectEntrySetin SchnittstelleLong2ObjectMap<V>- Gibt zurück:
- a EntrySet of the collection
-
keySet
- Angegeben von:
keySetin SchnittstelleLong2ObjectMap<V>- Angegeben von:
keySetin SchnittstelleMap<Long,V> - Setzt außer Kraft:
keySetin KlasseAbstractLong2ObjectMap<V>
-
values
- Angegeben von:
valuesin SchnittstelleLong2ObjectMap<V>- Angegeben von:
valuesin SchnittstelleMap<Long,V> - Setzt außer Kraft:
valuesin KlasseAbstractLong2ObjectMap<V>
-
forEach
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapType Specific forEach method to reduce boxing/unboxing- Angegeben von:
forEachin SchnittstelleLong2ObjectMap<V>- Setzt außer Kraft:
forEachin KlasseAbstractLong2ObjectMap<V>- Parameter:
action- processor of the values that are iterator over
-
replace
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapA Type Specific replace method to replace an existing value- Angegeben von:
replacein SchnittstelleLong2ObjectMap<V>- Setzt außer Kraft:
replacein KlasseAbstractLong2ObjectMap<V>- Parameter:
key- the element that should be searched foroldValue- the expected value to be replacednewValue- the value to replace the oldValue with.- Gibt zurück:
- true if the value got replaced
-
replace
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapA Type Specific replace method to reduce boxing/unboxing replace an existing value- Angegeben von:
replacein SchnittstelleLong2ObjectMap<V>- Setzt außer Kraft:
replacein KlasseAbstractLong2ObjectMap<V>- Parameter:
key- the element that should be searched forvalue- the value to replace with.- Gibt zurück:
- the present value or default return value
-
compute
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapA Type Specific compute method to reduce boxing/unboxing If the generated value equals the getDefaultReturnValue it will simply not insert it since that is treated as "null". A "Null Value" will be treated as "Do not insert/remove" based on how the Java has specified it.- Angegeben von:
computein SchnittstelleLong2ObjectMap<V>- Setzt außer Kraft:
computein KlasseAbstractLong2ObjectMap<V>- Parameter:
key- the key that should be computedmappingFunction- the operator that should generate the value- Gibt zurück:
- the result of the computation
-
computeIfAbsent
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapA Type Specific computeIfAbsent method to reduce boxing/unboxing If the generated value equals the getDefaultReturnValue it will simply not insert it since that is treated as "null". A "Null Value" will be treated as "Do not insert/remove" based on how the Java has specified it.- Angegeben von:
computeIfAbsentin SchnittstelleLong2ObjectMap<V>- Setzt außer Kraft:
computeIfAbsentin KlasseAbstractLong2ObjectMap<V>- Parameter:
key- the key that should be computedmappingFunction- the operator that should generate the value if not present- Gibt zurück:
- the result of the computed value or present value
-
supplyIfAbsent
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapA Supplier based computeIfAbsent function to fill the most used usecase of this function If the generated value equals the getDefaultReturnValue it will simply not insert it since that is treated as "null". A "Null Value" will be treated as "Do not insert/remove" based on how the Java has specified it.- Angegeben von:
supplyIfAbsentin SchnittstelleLong2ObjectMap<V>- Setzt außer Kraft:
supplyIfAbsentin KlasseAbstractLong2ObjectMap<V>- Parameter:
key- the key that should be computedvalueProvider- the value if not present- Gibt zurück:
- the result of the computed value or present value
-
computeIfPresent
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapA Type Specific compute method to reduce boxing/unboxing If the generated value equals the getDefaultReturnValue it will simply not insert it since that is treated as "null". A "Null Value" will be treated as "Do not insert/remove" based on how the Java has specified it.- Angegeben von:
computeIfPresentin SchnittstelleLong2ObjectMap<V>- Setzt außer Kraft:
computeIfPresentin KlasseAbstractLong2ObjectMap<V>- Parameter:
key- the key that should be computedmappingFunction- the operator that should generate the value if present- Gibt zurück:
- the result of the default return value or present value
-
merge
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapA Type Specific merge method to reduce boxing/unboxing If the generated value equals the getDefaultReturnValue it will simply not insert it since that is treated as "null". A "Null Value" will be treated as "Do not insert/remove" based on how the Java has specified it.- Angegeben von:
mergein SchnittstelleLong2ObjectMap<V>- Setzt außer Kraft:
mergein KlasseAbstractLong2ObjectMap<V>- Parameter:
key- the key that should be be searched forvalue- the value that should be merged withmappingFunction- the operator that should generate the new Value- Gibt zurück:
- the result of the merge
-
mergeAll
Beschreibung aus Schnittstelle kopiert:Long2ObjectMapA Bulk method for merging Maps. If the generated value equals the getDefaultReturnValue it will simply not insert it since that is treated as "null". A "Null Value" will be treated as "Do not insert/remove" based on how the Java has specified it.- Angegeben von:
mergeAllin SchnittstelleLong2ObjectMap<V>- Setzt außer Kraft:
mergeAllin KlasseAbstractLong2ObjectMap<V>- Parameter:
m- the entries that should be bulk addedmappingFunction- the operator that should generate the new Value
-
size
public int size() -
clear
public void clear() -
trim
public boolean trim(int size) Beschreibung aus Schnittstelle kopiert:ITrimmableTrims the original collection down to the size of the current elements or the requested size depending which is bigger- Angegeben von:
trimin SchnittstelleITrimmable- Parameter:
size- the requested trim size.- Gibt zurück:
- if the internal array has been trimmed.
-
clearAndTrim
public void clearAndTrim(int size) Beschreibung aus Schnittstelle kopiert:ITrimmableTrims the collection down to the requested size and clears all elements while doing so- Angegeben von:
clearAndTrimin SchnittstelleITrimmable- Parameter:
size- the amount of elements that should be allowed
-