public class CaseInsensitiveMap<K,V> extends AbstractHashedMap<K ,V> implements Serializable , Cloneable
Map.
Before keys are added to the map or compared to other existing keys, they are converted to all lowercase in a locale-independent fashion by using information from the Unicode data file.
Null keys are supported.
The keySet() method returns all lowercase keys, or nulls.
Example:
Map<String, String> map = new CaseInsensitiveMap<String, String>();
map.put("One", "One");
map.put("Two", "Two");
map.put(null, "Three");
map.put("one", "Four");
creates a
CaseInsensitiveMap with three entries.
map.get(null) returns
"Three" and
map.get("ONE") returns
"Four". The
Set returned by
keySet() equals
{"one", "two", null}.
This map will violate the detail of various Map and map view contracts. As a general rule, don't compare this map to other maps. In particular, you can't use decorators like ListOrderedMap on it, which silently assume that these contracts are fulfilled.
Note that CaseInsensitiveMap is not synchronized and is not thread-safe. If you wish to use this map from multiple threads concurrently, you must use appropriate synchronization. The simplest approach is to wrap this map using Collections. This class may throw exceptions when accessed by concurrent threads without synchronization.
AbstractHashedMap.EntrySet <K,V>, AbstractHashedMap.EntrySetIterator <K,V>, AbstractHashedMap.HashEntry <K,V>, AbstractHashedMap.HashIterator <K,V>, AbstractHashedMap.HashMapIterator <K,V>, AbstractHashedMap.KeySet <K>, AbstractHashedMap.KeySetIterator <K>, AbstractHashedMap.Values <V>, AbstractHashedMap.ValuesIterator <V> AbstractMap.SimpleEntry <K,V>, AbstractMap.SimpleImmutableEntry <K,V> DEFAULT_CAPACITY, DEFAULT_LOAD_FACTOR, DEFAULT_THRESHOLD, GETKEY_INVALID, GETVALUE_INVALID, MAXIMUM_CAPACITY, NO_NEXT_ENTRY, NO_PREVIOUS_ENTRY, NULL, REMOVE_INVALID, SETVALUE_INVALID| Constructor and Description |
|---|
CaseInsensitiveMap()
Constructs a new empty map with default size and load factor.
|
CaseInsensitiveMap(int initialCapacity)
Constructs a new, empty map with the specified initial capacity.
|
CaseInsensitiveMap(int initialCapacity, float loadFactor)
Constructs a new, empty map with the specified initial capacity and load factor.
|
CaseInsensitiveMap(Map
Constructor copying elements from another map.
|
| Modifier and Type | Method and Description |
|---|---|
CaseInsensitiveMap |
clone()
Clones the map without cloning the keys or values.
|
protected Object |
convertKey(Object
Overrides convertKey() from
AbstractHashedMap to convert keys to lower case.
|
addEntry, addMapping, calculateNewCapacity, calculateThreshold, checkCapacity, clear, containsKey, containsValue, createEntry, createEntrySetIterator, createKeySetIterator, createValuesIterator, destroyEntry, doReadObject, doWriteObject, ensureCapacity, entryHashCode, entryKey, entryNext, entrySet, entryValue, equals, get, getEntry, hash, hashCode, hashIndex, init, isEmpty, isEqualKey, isEqualValue, keySet, mapIterator, put, putAll, remove, removeEntry, removeMapping, reuseEntry, size, toString, updateEntry, valuesfinalize, getClass, notify, notifyAll, wait, wait, waitcompute, computeIfAbsent, computeIfPresent, forEach, getOrDefault, merge, putIfAbsent, remove, replace, replace, replaceAllpublic CaseInsensitiveMap()
public CaseInsensitiveMap(int initialCapacity)
initialCapacity - the initial capacity
IllegalArgumentException - if the initial capacity is negative
public CaseInsensitiveMap(int initialCapacity,
float loadFactor)
initialCapacity - the initial capacity
loadFactor - the load factor
IllegalArgumentException - if the initial capacity is negative
IllegalArgumentException - if the load factor is less than zero
public CaseInsensitiveMap(Map<? extends K ,? extends V> map)
Keys will be converted to lower case strings, which may cause some entries to be removed (if string representation of keys differ only by character case).
map - the map to copy
NullPointerException - if the map is null
protected ObjectconvertKey(Object key)
AbstractHashedMap to convert keys to lower case.
Returns AbstractHashedMap if key is null.
convertKey in class
AbstractHashedMap<K,V>
key - the key convert
public CaseInsensitiveMap<K ,V> clone()
clone in class
AbstractHashedMap<K,V>