org.apache.commons.collections.MultiMap |
Known Indirect Subclasses |
Defines a map that holds a collection of values against each key.
A MultiMap
is a Map with slightly different semantics.
Putting a value into the map will add the value to a Collection at that key.
Getting a value will return a Collection, holding all the values put to that key.
For example:
MultiMap mhm = new MultiHashMap(); mhm.put(key, "A"); mhm.put(key, "B"); mhm.put(key, "C"); Collection coll = (Collection) mhm.get(key);
coll
will be a collection containing "A", "B", "C".
NOTE: Additional methods were added to this interface in Commons Collections 3.1.
These were added solely for documentation purposes and do not change the interface
as they were defined in the superinterface Map
anyway.
Public Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Checks whether the map contains the value specified.
| |||||||||||
Gets the collection of values associated with the specified key.
| |||||||||||
Adds the value to the collection associated with the specified key.
| |||||||||||
Removes all values associated with the specified key.
| |||||||||||
Removes a specific value from map.
| |||||||||||
Gets the number of keys in this map.
| |||||||||||
Gets a collection containing all the values in the map.
|
[Expand]
Inherited Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
From interface
java.util.Map
|
Checks whether the map contains the value specified.
Implementations typically check all collections against all keys for the value. This cannot be mandated due to backwards compatability of this interface.
value | the value to search for |
---|
ClassCastException | if the value is of an invalid type |
---|---|
NullPointerException | if the value is null and null value are invalid |
Gets the collection of values associated with the specified key.
The returned value will implement Collection
. Implementations
are free to declare that they return Collection
subclasses
such as List
or Set
.
Implementations typically return null
if no values have
been mapped to the key, however the implementation may choose to
return an empty collection.
Implementations may choose to return a clone of the internal collection.
key | the key to retrieve |
---|
Collection
of values, implementations should
return null
for no mapping, but may return an empty collectionClassCastException | if the key is of an invalid type |
---|---|
NullPointerException | if the key is null and null keys are invalid |
Adds the value to the collection associated with the specified key.
Unlike a normal Map
the previous value is not replaced.
Instead the new value is added to the collection stored against the key.
The collection may be a List
, Set
or other
collection dependent on implementation.
key | the key to store against |
---|---|
value | the value to add to the collection at the key |
UnsupportedOperationException | if the map is unmodifiable |
---|---|
ClassCastException | if the key or value is of an invalid type |
NullPointerException | if the key or value is null and null is invalid |
IllegalArgumentException | if the key or value is invalid |
Removes all values associated with the specified key.
Implementations typically return null
from a subsequant
get(Object)
, however they may choose to return an empty collection.
key | the key to remove values from |
---|
Collection
of values removed, implementations should
return null
for no mapping found, but may return an empty collectionUnsupportedOperationException | if the map is unmodifiable |
---|---|
ClassCastException | if the key is of an invalid type |
NullPointerException | if the key is null and null keys are invalid |
Removes a specific value from map.
The item is removed from the collection mapped to the specified key. Other values attached to that key are unaffected.
If the last value for a key is removed, implementations typically
return null
from a subsequant get(Object)
, however
they may choose to return an empty collection.
key | the key to remove from |
---|---|
item | the item to remove |
UnsupportedOperationException | if the map is unmodifiable |
---|---|
ClassCastException | if the key or value is of an invalid type |
NullPointerException | if the key or value is null and null is invalid |
Gets the number of keys in this map.
Implementations typically return only the count of keys in the map This cannot be mandated due to backwards compatability of this interface.
Gets a collection containing all the values in the map.
Inplementations typically return a collection containing the combination of values from all keys. This cannot be mandated due to backwards compatability of this interface.