Klasse ImmutableChar2ObjectOpenHashMap<V>

java.lang.Object
java.util.AbstractMap<Character,V>
speiger.src.collections.chars.maps.abstracts.AbstractChar2ObjectMap<V>
speiger.src.collections.chars.maps.impl.immutable.ImmutableChar2ObjectOpenHashMap<V>
Typparameter:
V - the keyType of elements maintained by this Collection
Alle implementierten Schnittstellen:
Map<Character,V>, CharFunction<V>, Char2ObjectMap<V>, Char2ObjectOrderedMap<V>

public class ImmutableChar2ObjectOpenHashMap<V> extends AbstractChar2ObjectMap<V> implements Char2ObjectOrderedMap<V>
A Type Specific Custom implementation of the HashMap Instead of using Wrapper Object Arrays for storing keys and values there is dedicated arrays for storing keys and values. Extra to that there is a couple quality of life functions provided
  • Konstruktordetails

    • ImmutableChar2ObjectOpenHashMap

      public ImmutableChar2ObjectOpenHashMap(Character[] keys, V[] values)
      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 map
      values - the values that should be put into the map.
      Löst aus:
      IllegalStateException - if the keys and values do not match in lenght
    • ImmutableChar2ObjectOpenHashMap

      public ImmutableChar2ObjectOpenHashMap(Character[] keys, V[] values, float loadFactor)
      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 map
      values - the values that should be put into the map.
      loadFactor - the percentage of how full the backing array can be before they resize
      Löst aus:
      IllegalStateException - if the keys and values do not match in lenght
      IllegalStateException - if the loadfactor is either below/equal to 0 or above/equal to 1
    • ImmutableChar2ObjectOpenHashMap

      public ImmutableChar2ObjectOpenHashMap(char[] keys, V[] values)
      Helper constructor that allow to create a map from unboxed values
      Parameter:
      keys - the keys that should be put into the map
      values - the values that should be put into the map.
      Löst aus:
      IllegalStateException - if the keys and values do not match in lenght
    • ImmutableChar2ObjectOpenHashMap

      public ImmutableChar2ObjectOpenHashMap(char[] keys, V[] values, float loadFactor)
      Helper constructor that allow to create a map from unboxed values
      Parameter:
      keys - the keys that should be put into the map
      values - the values that should be put into the map.
      loadFactor - the percentage of how full the backing array can be before they resize
      Löst aus:
      IllegalStateException - if the keys and values do not match in lenght
      IllegalStateException - if the loadfactor is either below/equal to 0 or above/equal to 1
    • ImmutableChar2ObjectOpenHashMap

      public ImmutableChar2ObjectOpenHashMap(Map<? extends Character,? extends V> map)
      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 map
    • ImmutableChar2ObjectOpenHashMap

      public ImmutableChar2ObjectOpenHashMap(Map<? extends Character,? extends V> map, float loadFactor)
      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 map
      loadFactor - the percentage of how full the backing array can be before they resize
      Löst aus:
      IllegalStateException - if the loadfactor is either below/equal to 0 or above/equal to 1
    • ImmutableChar2ObjectOpenHashMap

      public ImmutableChar2ObjectOpenHashMap(Char2ObjectMap<V> map)
      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 map
    • ImmutableChar2ObjectOpenHashMap

      public ImmutableChar2ObjectOpenHashMap(Char2ObjectMap<V> map, float loadFactor)
      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 map
      loadFactor - the percentage of how full the backing array can be before they resize
      Löst aus:
      IllegalStateException - if the loadfactor is either below/equal to 0 or above/equal to 1
  • Methodendetails

    • put

      public V put(char key, V value)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      Type Specific method to reduce boxing/unboxing of values
      Angegeben von:
      put in Schnittstelle Char2ObjectMap<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

      public V putIfAbsent(char key, V value)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      Type Specific method to reduce boxing/unboxing of values
      Angegeben von:
      putIfAbsent in Schnittstelle Char2ObjectMap<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:
    • putAndMoveToFirst

      public V putAndMoveToFirst(char key, V value)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectOrderedMap
      A customized put method that allows you to insert into the first index.
      Angegeben von:
      putAndMoveToFirst in Schnittstelle Char2ObjectOrderedMap<V>
      Parameter:
      key - the key that should be inserted
      value - the value that should be inserted
      Gibt zurück:
      the previous present or default return value
      Siehe auch:
    • putAndMoveToLast

      public V putAndMoveToLast(char key, V value)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectOrderedMap
      A customized put method that allows you to insert into the last index. (This may be nessesary depending on the implementation)
      Angegeben von:
      putAndMoveToLast in Schnittstelle Char2ObjectOrderedMap<V>
      Parameter:
      key - the key that should be inserted
      value - the value that should be inserted
      Gibt zurück:
      the previous present or default return value
      Siehe auch:
    • moveToFirst

      public boolean moveToFirst(char key)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectOrderedMap
      A specific move method to move a given key/value to the first index.
      Angegeben von:
      moveToFirst in Schnittstelle Char2ObjectOrderedMap<V>
      Parameter:
      key - that should be moved to the first index
      Gibt zurück:
      true if the value was moved.
    • moveToLast

      public boolean moveToLast(char key)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectOrderedMap
      A specific move method to move a given key/value to the last index.
      Angegeben von:
      moveToLast in Schnittstelle Char2ObjectOrderedMap<V>
      Parameter:
      key - that should be moved to the first last
      Gibt zurück:
      true if the value was moved.
    • getAndMoveToFirst

      public V getAndMoveToFirst(char key)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectOrderedMap
      A Specific get method that allows to move teh given key/value int the first index.
      Angegeben von:
      getAndMoveToFirst in Schnittstelle Char2ObjectOrderedMap<V>
      Parameter:
      key - that is searched for
      Gibt zurück:
      the given value for the requested key or default return value
    • getAndMoveToLast

      public V getAndMoveToLast(char key)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectOrderedMap
      A Specific get method that allows to move teh given key/value int the last index.
      Angegeben von:
      getAndMoveToLast in Schnittstelle Char2ObjectOrderedMap<V>
      Parameter:
      key - that is searched for
      Gibt zurück:
      the given value for the requested key or default return value
    • containsKey

      public boolean containsKey(char key)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      Type Specific method to reduce boxing/unboxing of values
      Angegeben von:
      containsKey in Schnittstelle Char2ObjectMap<V>
      Setzt außer Kraft:
      containsKey in Klasse AbstractChar2ObjectMap<V>
      Parameter:
      key - element that is searched for
      Gibt zurück:
      if the key is present
    • containsKey

      @Deprecated public boolean containsKey(Object key)
      Veraltet.
      Angegeben von:
      containsKey in Schnittstelle Char2ObjectMap<V>
      Angegeben von:
      containsKey in Schnittstelle Map<Character,V>
      Setzt außer Kraft:
      containsKey in Klasse AbstractMap<Character,V>
      Parameter:
      key - that is searched for.
      Gibt zurück:
      true if found
      Siehe auch:
    • containsValue

      public boolean containsValue(Object value)
      Angegeben von:
      containsValue in Schnittstelle Map<Character,V>
      Setzt außer Kraft:
      containsValue in Klasse AbstractChar2ObjectMap<V>
    • remove

      public V remove(char key)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      Type Specific remove function to reduce boxing/unboxing
      Angegeben von:
      remove in Schnittstelle Char2ObjectMap<V>
      Parameter:
      key - the element that should be removed
      Gibt zurück:
      the value that was removed or default return value
    • removeOrDefault

      public V removeOrDefault(char key, V defaultValue)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      Type-Specific Remove function with a default return value if wanted.
      Angegeben von:
      removeOrDefault in Schnittstelle Char2ObjectMap<V>
      Parameter:
      key - the element that should be removed
      defaultValue - 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

      @Deprecated public V remove(Object key)
      Veraltet.
      Angegeben von:
      remove in Schnittstelle Char2ObjectMap<V>
      Angegeben von:
      remove in Schnittstelle Map<Character,V>
      Setzt außer Kraft:
      remove in Klasse AbstractChar2ObjectMap<V>
      Parameter:
      key - the element that should be removed
      Gibt zurück:
      the value that was removed or default return value
      Siehe auch:
    • remove

      public boolean remove(char key, V value)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      Type Specific remove function to reduce boxing/unboxing
      Angegeben von:
      remove in Schnittstelle Char2ObjectMap<V>
      Parameter:
      key - the element that should be removed
      value - the expected value that should be found
      Gibt zurück:
      true if the key and value was found and removed
      Siehe auch:
    • remove

      public boolean remove(Object key, Object value)
      Angegeben von:
      remove in Schnittstelle Char2ObjectMap<V>
      Angegeben von:
      remove in Schnittstelle Map<Character,V>
      Parameter:
      key - the element that should be removed
      value - the expected value that should be found
      Gibt zurück:
      true if the key and value was found and removed
      Siehe auch:
    • get

      public V get(char key)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      A Type Specific get method to reduce boxing/unboxing
      Angegeben von:
      get in Schnittstelle Char2ObjectMap<V>
      Parameter:
      key - the key that is searched for
      Gibt zurück:
      the searched value or default return value
    • get

      public V get(Object key)
      Angegeben von:
      get in Schnittstelle Char2ObjectMap<V>
      Angegeben von:
      get in Schnittstelle Map<Character,V>
      Setzt außer Kraft:
      get in Klasse AbstractChar2ObjectMap<V>
    • getOrDefault

      public V getOrDefault(char key, V defaultValue)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      A Type Specific getOrDefault method to reduce boxing/unboxing
      Angegeben von:
      getOrDefault in Schnittstelle Char2ObjectMap<V>
      Setzt außer Kraft:
      getOrDefault in Klasse AbstractChar2ObjectMap<V>
      Parameter:
      key - the key that is searched for
      defaultValue - the value that should be returned if the key is not present
      Gibt zurück:
      the searched value or defaultValue value
    • firstCharKey

      public char firstCharKey()
      Beschreibung aus Schnittstelle kopiert: Char2ObjectOrderedMap
      A method to get the first Key of a Map.
      Angegeben von:
      firstCharKey in Schnittstelle Char2ObjectOrderedMap<V>
      Gibt zurück:
      the first key in the map
    • pollFirstCharKey

      public char pollFirstCharKey()
      Beschreibung aus Schnittstelle kopiert: Char2ObjectOrderedMap
      A method to get and remove the first Key of a Map.
      Angegeben von:
      pollFirstCharKey in Schnittstelle Char2ObjectOrderedMap<V>
      Gibt zurück:
      the first key in the map
    • lastCharKey

      public char lastCharKey()
      Beschreibung aus Schnittstelle kopiert: Char2ObjectOrderedMap
      A method to get the last Key of a Map.
      Angegeben von:
      lastCharKey in Schnittstelle Char2ObjectOrderedMap<V>
      Gibt zurück:
      the last key in the map
    • pollLastCharKey

      public char pollLastCharKey()
      Beschreibung aus Schnittstelle kopiert: Char2ObjectOrderedMap
      A method to get and remove the last Key of a Map.
      Angegeben von:
      pollLastCharKey in Schnittstelle Char2ObjectOrderedMap<V>
      Gibt zurück:
      the last key in the map
    • firstValue

      public V firstValue()
      Beschreibung aus Schnittstelle kopiert: Char2ObjectOrderedMap
      A method to get the first Value of a Map.
      Angegeben von:
      firstValue in Schnittstelle Char2ObjectOrderedMap<V>
      Gibt zurück:
      the first key in the map
    • lastValue

      public V lastValue()
      Beschreibung aus Schnittstelle kopiert: Char2ObjectOrderedMap
      A method to get the last Value of a Map.
      Angegeben von:
      lastValue in Schnittstelle Char2ObjectOrderedMap<V>
      Gibt zurück:
      the last key in the map
    • char2ObjectEntrySet

      public ObjectOrderedSet<Char2ObjectMap.Entry<V>> char2ObjectEntrySet()
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      Type Sensitive EntrySet to reduce boxing/unboxing and optionally Temp Object Allocation.
      Angegeben von:
      char2ObjectEntrySet in Schnittstelle Char2ObjectMap<V>
      Angegeben von:
      char2ObjectEntrySet in Schnittstelle Char2ObjectOrderedMap<V>
      Gibt zurück:
      a EntrySet of the collection
    • keySet

      public CharOrderedSet keySet()
      Angegeben von:
      keySet in Schnittstelle Char2ObjectMap<V>
      Angegeben von:
      keySet in Schnittstelle Char2ObjectOrderedMap<V>
      Angegeben von:
      keySet in Schnittstelle Map<Character,V>
      Setzt außer Kraft:
      keySet in Klasse AbstractChar2ObjectMap<V>
    • values

      public ObjectCollection<V> values()
      Angegeben von:
      values in Schnittstelle Char2ObjectMap<V>
      Angegeben von:
      values in Schnittstelle Map<Character,V>
      Setzt außer Kraft:
      values in Klasse AbstractChar2ObjectMap<V>
    • copy

      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      A 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:
      copy in Schnittstelle Char2ObjectMap<V>
      Angegeben von:
      copy in Schnittstelle Char2ObjectOrderedMap<V>
      Setzt außer Kraft:
      copy in Klasse AbstractChar2ObjectMap<V>
      Gibt zurück:
      a Shallow Copy of the Map
    • forEach

      public void forEach(CharObjectConsumer<V> action)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      Type Specific forEach method to reduce boxing/unboxing
      Angegeben von:
      forEach in Schnittstelle Char2ObjectMap<V>
      Setzt außer Kraft:
      forEach in Klasse AbstractChar2ObjectMap<V>
      Parameter:
      action - processor of the values that are iterator over
    • replace

      public boolean replace(char key, V oldValue, V newValue)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      A Type Specific replace method to replace an existing value
      Angegeben von:
      replace in Schnittstelle Char2ObjectMap<V>
      Setzt außer Kraft:
      replace in Klasse AbstractChar2ObjectMap<V>
      Parameter:
      key - the element that should be searched for
      oldValue - the expected value to be replaced
      newValue - the value to replace the oldValue with.
      Gibt zurück:
      true if the value got replaced
    • replace

      public V replace(char key, V value)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      A Type Specific replace method to reduce boxing/unboxing replace an existing value
      Angegeben von:
      replace in Schnittstelle Char2ObjectMap<V>
      Setzt außer Kraft:
      replace in Klasse AbstractChar2ObjectMap<V>
      Parameter:
      key - the element that should be searched for
      value - the value to replace with.
      Gibt zurück:
      the present value or default return value
    • compute

      public V compute(char key, CharObjectUnaryOperator<V> mappingFunction)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      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". A "Null Value" will be treated as "Do not insert/remove" based on how the Java has specified it.
      Angegeben von:
      compute in Schnittstelle Char2ObjectMap<V>
      Setzt außer Kraft:
      compute in Klasse AbstractChar2ObjectMap<V>
      Parameter:
      key - the key that should be computed
      mappingFunction - the operator that should generate the value
      Gibt zurück:
      the result of the computation
    • computeIfAbsent

      public V computeIfAbsent(char key, CharFunction<V> mappingFunction)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      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". A "Null Value" will be treated as "Do not insert/remove" based on how the Java has specified it.
      Angegeben von:
      computeIfAbsent in Schnittstelle Char2ObjectMap<V>
      Setzt außer Kraft:
      computeIfAbsent in Klasse AbstractChar2ObjectMap<V>
      Parameter:
      key - the key that should be computed
      mappingFunction - the operator that should generate the value if not present
      Gibt zurück:
      the result of the computed value or present value
    • supplyIfAbsent

      public V supplyIfAbsent(char key, ObjectSupplier<V> valueProvider)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      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". A "Null Value" will be treated as "Do not insert/remove" based on how the Java has specified it.
      Angegeben von:
      supplyIfAbsent in Schnittstelle Char2ObjectMap<V>
      Setzt außer Kraft:
      supplyIfAbsent in Klasse AbstractChar2ObjectMap<V>
      Parameter:
      key - the key that should be computed
      valueProvider - the value if not present
      Gibt zurück:
      the result of the computed value or present value
    • computeIfPresent

      public V computeIfPresent(char key, CharObjectUnaryOperator<V> mappingFunction)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      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". A "Null Value" will be treated as "Do not insert/remove" based on how the Java has specified it.
      Angegeben von:
      computeIfPresent in Schnittstelle Char2ObjectMap<V>
      Setzt außer Kraft:
      computeIfPresent in Klasse AbstractChar2ObjectMap<V>
      Parameter:
      key - the key that should be computed
      mappingFunction - the operator that should generate the value if present
      Gibt zurück:
      the result of the default return value or present value
    • merge

      public V merge(char key, V value, ObjectObjectUnaryOperator<V,V> mappingFunction)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      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". A "Null Value" will be treated as "Do not insert/remove" based on how the Java has specified it.
      Angegeben von:
      merge in Schnittstelle Char2ObjectMap<V>
      Setzt außer Kraft:
      merge in Klasse AbstractChar2ObjectMap<V>
      Parameter:
      key - the key that should be be searched for
      value - the value that should be merged with
      mappingFunction - the operator that should generate the new Value
      Gibt zurück:
      the result of the merge
    • mergeAll

      public void mergeAll(Char2ObjectMap<V> m, ObjectObjectUnaryOperator<V,V> mappingFunction)
      Beschreibung aus Schnittstelle kopiert: Char2ObjectMap
      A 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:
      mergeAll in Schnittstelle Char2ObjectMap<V>
      Setzt außer Kraft:
      mergeAll in Klasse AbstractChar2ObjectMap<V>
      Parameter:
      m - the entries that should be bulk added
      mappingFunction - the operator that should generate the new Value
    • size

      public int size()
      Angegeben von:
      size in Schnittstelle Map<Character,V>
      Setzt außer Kraft:
      size in Klasse AbstractMap<Character,V>
    • clear

      public void clear()
      Angegeben von:
      clear in Schnittstelle Map<Character,V>
      Setzt außer Kraft:
      clear in Klasse AbstractMap<Character,V>