Class TByteFloatHashMap

All Implemented Interfaces:
TByteFloatMap, Externalizable, Serializable

public class TByteFloatHashMap extends TByteFloatHash implements TByteFloatMap, Externalizable
An open addressed Map implementation for byte keys and float values.
See Also:
  • Field Details

    • _values

      protected transient float[] _values
      the values of the map
  • Constructor Details

    • TByteFloatHashMap

      public TByteFloatHashMap()
      Creates a new TByteFloatHashMap instance with the default capacity and load factor.
    • TByteFloatHashMap

      public TByteFloatHashMap(int initialCapacity)
      Creates a new TByteFloatHashMap instance with a prime capacity equal to or greater than initialCapacity and with the default load factor.
      Parameters:
      initialCapacity - an int value
    • TByteFloatHashMap

      public TByteFloatHashMap(int initialCapacity, float loadFactor)
      Creates a new TByteFloatHashMap instance with a prime capacity equal to or greater than initialCapacity and with the specified load factor.
      Parameters:
      initialCapacity - an int value
      loadFactor - a float value
    • TByteFloatHashMap

      public TByteFloatHashMap(int initialCapacity, float loadFactor, byte noEntryKey, float noEntryValue)
      Creates a new TByteFloatHashMap instance with a prime capacity equal to or greater than initialCapacity and with the specified load factor.
      Parameters:
      initialCapacity - an int value
      loadFactor - a float value
      noEntryKey - a byte value that represents null for the Key set.
      noEntryValue - a float value that represents null for the Value set.
    • TByteFloatHashMap

      public TByteFloatHashMap(byte[] keys, float[] values)
      Creates a new TByteFloatHashMap instance containing all of the entries in the map passed in.
      Parameters:
      keys - a byte array containing the keys for the matching values.
      values - a float array containing the values.
    • TByteFloatHashMap

      public TByteFloatHashMap(TByteFloatMap map)
      Creates a new TByteFloatHashMap instance containing all of the entries in the map passed in.
      Parameters:
      map - a TByteFloatMap that will be duplicated.
  • Method Details

    • setUp

      protected int setUp(int initialCapacity)
      initializes the hashtable to a prime capacity which is at least initialCapacity + 1.
      Overrides:
      setUp in class TByteFloatHash
      Parameters:
      initialCapacity - an int value
      Returns:
      the actual capacity chosen
    • rehash

      protected void rehash(int newCapacity)
      Rehashes the set.
      Specified by:
      rehash in class THash
      Parameters:
      newCapacity - an int value
    • put

      public float put(byte key, float value)
      Inserts a key/value pair into the map.
      Specified by:
      put in interface TByteFloatMap
      Returns:
      the previous value associated with key, or the "no entry" value if none was found (see TByteFloatMap.getNoEntryValue()).
    • putIfAbsent

      public float putIfAbsent(byte key, float value)
      Inserts a key/value pair into the map if the specified key is not already associated with a value.
      Specified by:
      putIfAbsent in interface TByteFloatMap
      Returns:
      the previous value associated with key, or the "no entry" value if none was found (see TByteFloatMap.getNoEntryValue()).
    • putAll

      public void putAll(Map<? extends Byte,? extends Float> map)
      Put all the entries from the given Map into this map.
      Specified by:
      putAll in interface TByteFloatMap
      Parameters:
      map - The Map from which entries will be obtained to put into this map.
    • putAll

      public void putAll(TByteFloatMap map)
      Put all the entries from the given map into this map.
      Specified by:
      putAll in interface TByteFloatMap
      Parameters:
      map - The map from which entries will be obtained to put into this map.
    • get

      public float get(byte key)
      Retrieves the value for key.
      Specified by:
      get in interface TByteFloatMap
      Returns:
      the previous value associated with key, or the "no entry" value if none was found (see TByteFloatMap.getNoEntryValue()).
    • clear

      public void clear()
      Empties the collection.
      Specified by:
      clear in interface TByteFloatMap
      Overrides:
      clear in class THash
    • isEmpty

      public boolean isEmpty()
      Tells whether this set is currently holding any elements.
      Specified by:
      isEmpty in interface TByteFloatMap
      Overrides:
      isEmpty in class THash
      Returns:
      a boolean value
    • remove

      public float remove(byte key)
      Deletes a key/value pair from the map.
      Specified by:
      remove in interface TByteFloatMap
      Parameters:
      key - an byte value
      Returns:
      the previous value associated with key, or the "no entry" value if none was found (see TByteFloatMap.getNoEntryValue()).
    • removeAt

      protected void removeAt(int index)
      Releases the element currently stored at index.
      Overrides:
      removeAt in class TByteFloatHash
      Parameters:
      index - an int value
    • keySet

      public TByteSet keySet()
      Returns the keys of the map as a TByteSet
      Specified by:
      keySet in interface TByteFloatMap
      Returns:
      the keys of the map as a TByteSet
    • keys

      public byte[] keys()
      Returns the keys of the map as an array of byte values.
      Specified by:
      keys in interface TByteFloatMap
      Returns:
      the keys of the map as an array of byte values.
    • keys

      public byte[] keys(byte[] array)
      Returns the keys of the map.
      Specified by:
      keys in interface TByteFloatMap
      Parameters:
      array - the array into which the elements of the list are to be stored, if it is big enough; otherwise, a new array of the same type is allocated for this purpose.
      Returns:
      the keys of the map as an array.
    • valueCollection

      public TFloatCollection valueCollection()
      Returns the values of the map as a TFloatCollection
      Specified by:
      valueCollection in interface TByteFloatMap
      Returns:
      the values of the map as a TFloatCollection
    • values

      public float[] values()
      Returns the values of the map as an array of #e# values.
      Specified by:
      values in interface TByteFloatMap
      Returns:
      the values of the map as an array of #e# values.
    • values

      public float[] values(float[] array)
      Returns the values of the map using an existing array.
      Specified by:
      values in interface TByteFloatMap
      Parameters:
      array - the array into which the elements of the list are to be stored, if it is big enough; otherwise, a new array of the same type is allocated for this purpose.
      Returns:
      the values of the map as an array of #e# values.
    • containsValue

      public boolean containsValue(float val)
      Checks for the presence of val in the values of the map.
      Specified by:
      containsValue in interface TByteFloatMap
    • containsKey

      public boolean containsKey(byte key)
      Checks for the present of key in the keys of the map.
      Specified by:
      containsKey in interface TByteFloatMap
    • iterator

      public TByteFloatIterator iterator()
      Specified by:
      iterator in interface TByteFloatMap
      Returns:
      a TByteFloatIterator with access to this map's keys and values
    • forEachKey

      public boolean forEachKey(TByteProcedure procedure)
      Executes procedure for each key in the map.
      Specified by:
      forEachKey in interface TByteFloatMap
      Parameters:
      procedure - a TByteProcedure value
      Returns:
      false if the loop over the keys terminated because the procedure returned false for some key.
    • forEachValue

      public boolean forEachValue(TFloatProcedure procedure)
      Executes procedure for each value in the map.
      Specified by:
      forEachValue in interface TByteFloatMap
      Parameters:
      procedure - a T#F#Procedure value
      Returns:
      false if the loop over the values terminated because the procedure returned false for some value.
    • forEachEntry

      public boolean forEachEntry(TByteFloatProcedure procedure)
      Executes procedure for each key/value entry in the map.
      Specified by:
      forEachEntry in interface TByteFloatMap
      Parameters:
      procedure - a TOByteFloatProcedure value
      Returns:
      false if the loop over the entries terminated because the procedure returned false for some entry.
    • transformValues

      public void transformValues(TFloatFunction function)
      Transform the values in this map using function.
      Specified by:
      transformValues in interface TByteFloatMap
      Parameters:
      function - a TFloatFunction value
    • retainEntries

      public boolean retainEntries(TByteFloatProcedure procedure)
      Retains only those entries in the map for which the procedure returns a true value.
      Specified by:
      retainEntries in interface TByteFloatMap
      Parameters:
      procedure - determines which entries to keep
      Returns:
      true if the map was modified.
    • increment

      public boolean increment(byte key)
      Increments the primitive value mapped to key by 1
      Specified by:
      increment in interface TByteFloatMap
      Parameters:
      key - the key of the value to increment
      Returns:
      true if a mapping was found and modified.
    • adjustValue

      public boolean adjustValue(byte key, float amount)
      Adjusts the primitive value mapped to key.
      Specified by:
      adjustValue in interface TByteFloatMap
      Parameters:
      key - the key of the value to increment
      amount - the amount to adjust the value by.
      Returns:
      true if a mapping was found and modified.
    • adjustOrPutValue

      public float adjustOrPutValue(byte key, float adjust_amount, float put_amount)
      Adjusts the primitive value mapped to the key if the key is present in the map. Otherwise, the put_amount is put in the map.
      Specified by:
      adjustOrPutValue in interface TByteFloatMap
      Parameters:
      key - the key of the value to increment
      adjust_amount - the amount to adjust the value by
      put_amount - the value put into the map if the key is not present
      Returns:
      the value present in the map after the adjustment or put operation
    • equals

      public boolean equals(Object other)
      Overrides:
      equals in class Object
    • hashCode

      public int hashCode()
      Overrides:
      hashCode in class Object
    • toString

      public String toString()
      Overrides:
      toString in class Object
    • writeExternal

      public void writeExternal(ObjectOutput out) throws IOException
      Specified by:
      writeExternal in interface Externalizable
      Overrides:
      writeExternal in class TByteFloatHash
      Throws:
      IOException
    • readExternal

      public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException
      Specified by:
      readExternal in interface Externalizable
      Overrides:
      readExternal in class TByteFloatHash
      Throws:
      IOException
      ClassNotFoundException