org.apache.commons.collections.map
Class CaseInsensitiveMap

java.lang.Object
  |
  +--java.util.AbstractMap
        |
        +--org.apache.commons.collections.map.AbstractHashedMap
              |
              +--org.apache.commons.collections.map.CaseInsensitiveMap
All Implemented Interfaces:
java.lang.Cloneable, IterableMap, java.util.Map, java.io.Serializable

public class CaseInsensitiveMap
extends AbstractHashedMap
implements java.io.Serializable, java.lang.Cloneable

A case-insensitive Map.

As entries are added to the map, keys are converted to all lowercase. A new key is compared to existing keys by comparing newKey.toString().toLower() to the lowercase values in the current KeySet.

Null keys are supported.

The keySet() method returns all lowercase keys, or nulls.

Example:


  Map map = new CaseInsensitiveMap();
  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}.

Since:
Commons Collections 3.0
Version:
$Revision: 1.4 $ $Date: 2004/02/18 01:13:19 $
Author:
Commons-Collections team
See Also:
Serialized Form

Constructor Summary
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(java.util.Map map)
          Constructor copying elements from another map.
 
Method Summary
 java.lang.Object clone()
          Clones the map without cloning the keys or values.
 
Methods inherited from class org.apache.commons.collections.map.AbstractHashedMap
clear, containsKey, containsValue, entrySet, equals, get, hashCode, isEmpty, keySet, mapIterator, put, putAll, remove, size, toString, values
 
Methods inherited from class java.lang.Object
getClass, notify, notifyAll, wait, wait, wait
 

Constructor Detail

CaseInsensitiveMap

public CaseInsensitiveMap()
Constructs a new empty map with default size and load factor.


CaseInsensitiveMap

public CaseInsensitiveMap(int initialCapacity)
Constructs a new, empty map with the specified initial capacity.

Parameters:
initialCapacity - the initial capacity
Throws:
java.lang.IllegalArgumentException - if the initial capacity is less than one

CaseInsensitiveMap

public CaseInsensitiveMap(int initialCapacity,
                          float loadFactor)
Constructs a new, empty map with the specified initial capacity and load factor.

Parameters:
initialCapacity - the initial capacity
loadFactor - the load factor
Throws:
java.lang.IllegalArgumentException - if the initial capacity is less than one
java.lang.IllegalArgumentException - if the load factor is less than zero

CaseInsensitiveMap

public CaseInsensitiveMap(java.util.Map map)
Constructor copying elements from another 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).

Parameters:
map - the map to copy
Throws:
java.lang.NullPointerException - if the map is null
Method Detail

clone

public java.lang.Object clone()
Clones the map without cloning the keys or values.

Overrides:
clone in class AbstractHashedMap
Returns:
a shallow clone


Copyright © 2001-2004 The Apache Software Foundation. All Rights Reserved.