Package org.jibx.runtime.impl
Class StringIntHashMap
- java.lang.Object
-
- org.jibx.runtime.impl.StringIntHashMap
-
public class StringIntHashMap extends Object
Hash map usingStringvalues as keys mapped to primitiveintvalues. This implementation is unsynchronized in order to provide the best possible performance for typical usage scenarios, so explicit synchronization must be implemented by a wrapper class or directly by the application in cases where instances are modified in a multithreaded environment. The map implementation is not very efficient when resizing, but works well when the size of the map is known in advance.- Version:
- 1.1
- Author:
- Dennis M. Sosnoski
-
-
Field Summary
Fields Modifier and Type Field Description protected static doubleDEFAULT_FILLDefault fill fraction allowed before growing table.static intDEFAULT_NOT_FOUNDDefault value returned when key not found in table.protected intm_arraySizeSize of array used for keys.protected intm_entryCountNumber of entries present in table.protected intm_entryLimitEntries allowed before growing table.protected doublem_fillFractionFill fraction allowed for this hash table.protected intm_hitOffsetOffset added (modulo table size) to slot number on collision.protected String[]m_keyTableArray of key table slots.protected intm_notFoundValueValue returned when key not found in table.protected int[]m_valueTableArray of value table slots.protected static intMINIMUM_SIZEMinimum size used for hash table.
-
Constructor Summary
Constructors Constructor Description StringIntHashMap()Default constructor.StringIntHashMap(int count)Constructor with only size supplied.StringIntHashMap(int count, double fill)Constructor with size and fill fraction specified.StringIntHashMap(int count, double fill, int miss)Constructor with full specification.StringIntHashMap(StringIntHashMap base)Copy (clone) constructor.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intadd(String key, int value)Add an entry to the table.Objectclone()Construct a copy of the table.booleancontainsKey(String key)Check if an entry is present in the table.intget(String key)Find an entry in the table.protected voidinternalRemove(int slot)Internal remove pair from the table.intremove(String key)Remove an entry from the table.
-
-
-
Field Detail
-
DEFAULT_NOT_FOUND
public static final int DEFAULT_NOT_FOUND
Default value returned when key not found in table.- See Also:
- Constant Field Values
-
DEFAULT_FILL
protected static final double DEFAULT_FILL
Default fill fraction allowed before growing table.- See Also:
- Constant Field Values
-
MINIMUM_SIZE
protected static final int MINIMUM_SIZE
Minimum size used for hash table.- See Also:
- Constant Field Values
-
m_fillFraction
protected final double m_fillFraction
Fill fraction allowed for this hash table.
-
m_entryCount
protected int m_entryCount
Number of entries present in table.
-
m_entryLimit
protected int m_entryLimit
Entries allowed before growing table.
-
m_arraySize
protected int m_arraySize
Size of array used for keys.
-
m_hitOffset
protected int m_hitOffset
Offset added (modulo table size) to slot number on collision.
-
m_keyTable
protected String[] m_keyTable
Array of key table slots.
-
m_valueTable
protected int[] m_valueTable
Array of value table slots.
-
m_notFoundValue
protected int m_notFoundValue
Value returned when key not found in table.
-
-
Constructor Detail
-
StringIntHashMap
public StringIntHashMap(int count, double fill, int miss)Constructor with full specification.- Parameters:
count- number of values to assume in initial sizing of tablefill- fraction full allowed for table before growingmiss- value returned when key not found in table
-
StringIntHashMap
public StringIntHashMap(int count, double fill)Constructor with size and fill fraction specified. Uses default hash technique and value returned when key not found in table.- Parameters:
count- number of values to assume in initial sizing of tablefill- fraction full allowed for table before growing
-
StringIntHashMap
public StringIntHashMap(int count)
Constructor with only size supplied. Uses default hash technique and values for fill fraction and value returned when key not found in table.- Parameters:
count- number of values to assume in initial sizing of table
-
StringIntHashMap
public StringIntHashMap()
Default constructor.
-
StringIntHashMap
public StringIntHashMap(StringIntHashMap base)
Copy (clone) constructor.- Parameters:
base- instance being copied
-
-
Method Detail
-
internalRemove
protected void internalRemove(int slot)
Internal remove pair from the table. Removes the pair from the table by setting the key entry tonulland adjusting the count present, then chains through the table to reinsert any other pairs which may have collided with the removed pair. If the associated value is an object reference, it should be set tonullbefore this method is called.- Parameters:
slot- index number of pair to be removed
-
add
public int add(String key, int value)
Add an entry to the table. If the key is already present in the table, this replaces the existing value associated with the key.- Parameters:
key- key to be added to table (non-null)value- associated value for key- Returns:
- value previously associated with key, or reserved not found value if key not previously present in table
-
containsKey
public final boolean containsKey(String key)
Check if an entry is present in the table. This method is supplied to support the use of values matching the reserved not found value.- Parameters:
key- key for entry to be found- Returns:
trueif key found in table,falseif not
-
get
public final int get(String key)
Find an entry in the table.- Parameters:
key- key for entry to be returned- Returns:
- value for key, or reserved not found value if key not found
-
remove
public int remove(String key)
Remove an entry from the table. If multiple entries are present with the same key value, only the first one found will be removed.- Parameters:
key- key to be removed from table- Returns:
- value associated with removed key, or reserved not found value if key not found in table
-
-