- java.lang.Object
-
- io.netty5.util.collection.ByteObjectHashMap<V>
-
- Type Parameters:
V
- The value type stored in the map.
- All Implemented Interfaces:
ByteObjectMap<V>
,Map<Byte,V>
public class ByteObjectHashMap<V> extends Object implements ByteObjectMap<V>
A hash map implementation ofByteObjectMap
that uses open addressing for keys. To minimize the memory footprint, this class uses open addressing rather than chaining. Collisions are resolved using linear probing. Deletions implement compaction, so cost of remove can approach O(N) for full maps, which makes a small loadFactor recommended.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface io.netty5.util.collection.ByteObjectMap
ByteObjectMap.PrimitiveEntry<V>
-
-
Field Summary
Fields Modifier and Type Field Description static int
DEFAULT_CAPACITY
Default initial capacity.static float
DEFAULT_LOAD_FACTOR
Default load factor.
-
Constructor Summary
Constructors Constructor Description ByteObjectHashMap()
ByteObjectHashMap(int initialCapacity)
ByteObjectHashMap(int initialCapacity, float loadFactor)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
clear()
boolean
containsKey(byte key)
Indicates whether or not this map contains a value for the specified key.boolean
containsKey(Object key)
boolean
containsValue(Object value)
Iterable<ByteObjectMap.PrimitiveEntry<V>>
entries()
Gets an iterable to traverse over the primitive entries contained in this map.Set<Map.Entry<Byte,V>>
entrySet()
boolean
equals(Object obj)
V
get(byte key)
Gets the value in the map with the specified key.V
get(Object key)
int
hashCode()
boolean
isEmpty()
Set<Byte>
keySet()
protected String
keyToString(byte key)
Helper method called bytoString()
in order to convert a single map key into a string.V
put(byte key, V value)
Puts the given entry into the map.V
put(Byte key, V value)
void
putAll(Map<? extends Byte,? extends V> sourceMap)
V
remove(byte key)
Removes the entry with the specified key.V
remove(Object key)
int
size()
String
toString()
Collection<V>
values()
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface java.util.Map
compute, computeIfAbsent, computeIfPresent, forEach, getOrDefault, merge, putIfAbsent, remove, replace, replace, replaceAll
-
-
-
-
Field Detail
-
DEFAULT_CAPACITY
public static final int DEFAULT_CAPACITY
Default initial capacity. Used if not specified in the constructor- See Also:
- Constant Field Values
-
DEFAULT_LOAD_FACTOR
public static final float DEFAULT_LOAD_FACTOR
Default load factor. Used if not specified in the constructor- See Also:
- Constant Field Values
-
-
Method Detail
-
get
public V get(byte key)
Description copied from interface:ByteObjectMap
Gets the value in the map with the specified key.- Specified by:
get
in interfaceByteObjectMap<V>
- Parameters:
key
- the key whose associated value is to be returned.- Returns:
- the value or
null
if the key was not found in the map.
-
put
public V put(byte key, V value)
Description copied from interface:ByteObjectMap
Puts the given entry into the map.- Specified by:
put
in interfaceByteObjectMap<V>
- Parameters:
key
- the key of the entry.value
- the value of the entry.- Returns:
- the previous value for this key or
null
if there was no previous mapping.
-
remove
public V remove(byte key)
Description copied from interface:ByteObjectMap
Removes the entry with the specified key.- Specified by:
remove
in interfaceByteObjectMap<V>
- Parameters:
key
- the key for the entry to be removed from this map.- Returns:
- the previous value for the key, or
null
if there was no mapping.
-
containsKey
public boolean containsKey(byte key)
Description copied from interface:ByteObjectMap
Indicates whether or not this map contains a value for the specified key.- Specified by:
containsKey
in interfaceByteObjectMap<V>
-
containsValue
public boolean containsValue(Object value)
- Specified by:
containsValue
in interfaceMap<Byte,V>
-
entries
public Iterable<ByteObjectMap.PrimitiveEntry<V>> entries()
Description copied from interface:ByteObjectMap
Gets an iterable to traverse over the primitive entries contained in this map. As an optimization, theByteObjectMap.PrimitiveEntry
s returned by theIterator
may change as theIterator
progresses. The caller should not rely onByteObjectMap.PrimitiveEntry
key/value stability.- Specified by:
entries
in interfaceByteObjectMap<V>
-
hashCode
public int hashCode()
-
equals
public boolean equals(Object obj)
-
containsKey
public boolean containsKey(Object key)
- Specified by:
containsKey
in interfaceMap<Byte,V>
-
keyToString
protected String keyToString(byte key)
Helper method called bytoString()
in order to convert a single map key into a string. This is protected to allow subclasses to override the appearance of a given key.
-
-