Package io.netty.util.collection
Class ByteObjectHashMap<V>
- java.lang.Object
-
- io.netty.util.collection.ByteObjectHashMap<V>
-
- Type Parameters:
V- The value type stored in the map.
- All Implemented Interfaces:
ByteObjectMap<V>,java.util.Map<java.lang.Byte,V>
public class ByteObjectHashMap<V> extends java.lang.Object implements ByteObjectMap<V>
A hash map implementation ofByteObjectMapthat 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.netty.util.collection.ByteObjectMap
ByteObjectMap.PrimitiveEntry<V>
-
-
Field Summary
Fields Modifier and Type Field Description static intDEFAULT_CAPACITYDefault initial capacity.static floatDEFAULT_LOAD_FACTORDefault 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 voidclear()booleancontainsKey(byte key)Indicates whether or not this map contains a value for the specified key.booleancontainsKey(java.lang.Object key)booleancontainsValue(java.lang.Object value)java.lang.Iterable<ByteObjectMap.PrimitiveEntry<V>>entries()Gets an iterable to traverse over the primitive entries contained in this map.java.util.Set<java.util.Map.Entry<java.lang.Byte,V>>entrySet()booleanequals(java.lang.Object obj)Vget(byte key)Gets the value in the map with the specified key.Vget(java.lang.Object key)inthashCode()booleanisEmpty()java.util.Set<java.lang.Byte>keySet()protected java.lang.StringkeyToString(byte key)Helper method called bytoString()in order to convert a single map key into a string.Vput(byte key, V value)Puts the given entry into the map.Vput(java.lang.Byte key, V value)voidputAll(java.util.Map<? extends java.lang.Byte,? extends V> sourceMap)Vremove(byte key)Removes the entry with the specified key.Vremove(java.lang.Object key)intsize()java.lang.StringtoString()java.util.Collection<V>values()
-
-
-
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:ByteObjectMapGets the value in the map with the specified key.- Specified by:
getin interfaceByteObjectMap<V>- Parameters:
key- the key whose associated value is to be returned.- Returns:
- the value or
nullif the key was not found in the map.
-
put
public V put(byte key, V value)
Description copied from interface:ByteObjectMapPuts the given entry into the map.- Specified by:
putin interfaceByteObjectMap<V>- Parameters:
key- the key of the entry.value- the value of the entry.- Returns:
- the previous value for this key or
nullif there was no previous mapping.
-
putAll
public void putAll(java.util.Map<? extends java.lang.Byte,? extends V> sourceMap)
- Specified by:
putAllin interfacejava.util.Map<java.lang.Byte,V>
-
remove
public V remove(byte key)
Description copied from interface:ByteObjectMapRemoves the entry with the specified key.- Specified by:
removein interfaceByteObjectMap<V>- Parameters:
key- the key for the entry to be removed from this map.- Returns:
- the previous value for the key, or
nullif there was no mapping.
-
size
public int size()
- Specified by:
sizein interfacejava.util.Map<java.lang.Byte,V>
-
isEmpty
public boolean isEmpty()
- Specified by:
isEmptyin interfacejava.util.Map<java.lang.Byte,V>
-
clear
public void clear()
- Specified by:
clearin interfacejava.util.Map<java.lang.Byte,V>
-
containsKey
public boolean containsKey(byte key)
Description copied from interface:ByteObjectMapIndicates whether or not this map contains a value for the specified key.- Specified by:
containsKeyin interfaceByteObjectMap<V>
-
containsValue
public boolean containsValue(java.lang.Object value)
- Specified by:
containsValuein interfacejava.util.Map<java.lang.Byte,V>
-
entries
public java.lang.Iterable<ByteObjectMap.PrimitiveEntry<V>> entries()
Description copied from interface:ByteObjectMapGets an iterable to traverse over the primitive entries contained in this map. As an optimization, theByteObjectMap.PrimitiveEntrys returned by theIteratormay change as theIteratorprogresses. The caller should not rely onByteObjectMap.PrimitiveEntrykey/value stability.- Specified by:
entriesin interfaceByteObjectMap<V>
-
values
public java.util.Collection<V> values()
- Specified by:
valuesin interfacejava.util.Map<java.lang.Byte,V>
-
hashCode
public int hashCode()
- Specified by:
hashCodein interfacejava.util.Map<java.lang.Byte,V>- Overrides:
hashCodein classjava.lang.Object
-
equals
public boolean equals(java.lang.Object obj)
- Specified by:
equalsin interfacejava.util.Map<java.lang.Byte,V>- Overrides:
equalsin classjava.lang.Object
-
containsKey
public boolean containsKey(java.lang.Object key)
- Specified by:
containsKeyin interfacejava.util.Map<java.lang.Byte,V>
-
get
public V get(java.lang.Object key)
- Specified by:
getin interfacejava.util.Map<java.lang.Byte,V>
-
put
public V put(java.lang.Byte key, V value)
- Specified by:
putin interfacejava.util.Map<java.lang.Byte,V>
-
remove
public V remove(java.lang.Object key)
- Specified by:
removein interfacejava.util.Map<java.lang.Byte,V>
-
keySet
public java.util.Set<java.lang.Byte> keySet()
- Specified by:
keySetin interfacejava.util.Map<java.lang.Byte,V>
-
entrySet
public java.util.Set<java.util.Map.Entry<java.lang.Byte,V>> entrySet()
- Specified by:
entrySetin interfacejava.util.Map<java.lang.Byte,V>
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
keyToString
protected java.lang.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.
-
-