Class AbstractMultiValuedMapDecorator<K,V> 
- Type Parameters:
- K- the type of key elements
- V- the type of value elements
- All Implemented Interfaces:
- Serializable,- MultiValuedMap<K,- V> 
- Direct Known Subclasses:
- TransformedMultiValuedMap,- UnmodifiableMultiValuedMap
MultiValuedMap to provide additional behavior.
 
 Each method call made on this MultiValuedMap is forwarded to the
 decorated MultiValuedMap. This class is used as a framework to build
 to extensions such as synchronized and unmodifiable behavior.
 
- Since:
- 4.1
- See Also:
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedConstructor that wraps (not copies).
- 
Method SummaryModifier and TypeMethodDescriptionMap<K, Collection<V>> asMap()Returns a view of this multivalued map as aMapfrom each distinct key to the non-empty collection of that key's associated values.voidclear()Removes all of the mappings from this map (optional operation).booleancontainsKey(Object key) Returnstrueif this map contains a mapping for the specified key.booleancontainsMapping(Object key, Object value) Checks whether the map contains a mapping for the specified key and value.booleancontainsValue(Object value) Checks whether the map contains at least one mapping for the specified value.protected MultiValuedMap<K, V> The decorated multivalued map.entries()Returns aCollectionview of the mappings contained in this multivalued map.booleanGets a view collection of the values associated with the specified key.inthashCode()booleanisEmpty()Returnstrueif this map contains no key-value mappings.keys()Returns aMultiSetview of the keys contained in this multivalued map.keySet()Returns aSetview of the keys contained in this multivalued map.Obtains aMapIteratorover this multivalued map.booleanAdds a key-value mapping to this multivalued map.booleanCopies all mappings from the specified map to this multivalued map (optional operation).booleanAdds a mapping to the specified key for all values contained in the given Iterable.booleanputAll(MultiValuedMap<? extends K, ? extends V> map) Copies all mappings from the specified map to this multivalued map (optional operation).Removes all values associated with the specified key.booleanremoveMapping(Object key, Object item) Removes a key-value mapping from the map.intsize()Gets the total size of the map.toString()values()Gets aCollectionview of all values contained in this multivalued map.
- 
Constructor Details- 
AbstractMultiValuedMapDecoratorConstructor that wraps (not copies).- Parameters:
- map- the map to decorate, must not be null
- Throws:
- NullPointerException- if the map is null
 
 
- 
- 
Method Details- 
asMapDescription copied from interface:MultiValuedMapReturns a view of this multivalued map as aMapfrom each distinct key to the non-empty collection of that key's associated values.Note that this.asMap().get(k)is equivalent tothis.get(k)only whenkis a key contained in the multivalued map; otherwise it returnsnullas opposed to an empty collection.Changes to the returned map or the collections that serve as its values will update the underlying multivalued map, and vice versa. The map does not support putorputAll, nor do its entries supportsetValue.- Specified by:
- asMapin interface- MultiValuedMap<K,- V> 
- Returns:
- a map view of the mappings in this multivalued map
 
- 
clearDescription copied from interface:MultiValuedMapRemoves all of the mappings from this map (optional operation).The map will be empty after this call returns. - Specified by:
- clearin interface- MultiValuedMap<K,- V> 
 
- 
containsKeyDescription copied from interface:MultiValuedMapReturnstrueif this map contains a mapping for the specified key. More formally, returnstrueif and only if this map contains a mapping for a keyksuch that(key==null ? k==null : key.equals(k)). (There can be at most one such mapping.)- Specified by:
- containsKeyin interface- MultiValuedMap<K,- V> 
- Parameters:
- key- key whose presence in this map is to be tested
- Returns:
- true if this map contains a mapping for the specified key
 
- 
containsMappingDescription copied from interface:MultiValuedMapChecks whether the map contains a mapping for the specified key and value.- Specified by:
- containsMappingin interface- MultiValuedMap<K,- V> 
- Parameters:
- key- the key to search for
- value- the value to search for
- Returns:
- true if the map contains the value
 
- 
containsValueDescription copied from interface:MultiValuedMapChecks whether the map contains at least one mapping for the specified value.- Specified by:
- containsValuein interface- MultiValuedMap<K,- V> 
- Parameters:
- value- the value to search for
- Returns:
- true if the map contains the value
 
- 
decoratedThe decorated multivalued map.- Returns:
- the map to decorate
 
- 
entriesDescription copied from interface:MultiValuedMapReturns aCollectionview of the mappings contained in this multivalued map.The collection is backed by the map, so changes to the map are reflected in the collection, and vice-versa. - Specified by:
- entriesin interface- MultiValuedMap<K,- V> 
- Returns:
- a set view of the mappings contained in this map
 
- 
equals
- 
getDescription copied from interface:MultiValuedMapGets a view collection of the values associated with the specified key.This method will return an empty collection if MultiValuedMap.containsKey(Object)returnsfalse. Changes to the returned collection will update the underlyingMultiValuedMapand vice-versa.- Specified by:
- getin interface- MultiValuedMap<K,- V> 
- Parameters:
- key- the key to retrieve
- Returns:
- the Collectionof values, implementations should return an empty collection for no mapping
 
- 
hashCode
- 
isEmptyDescription copied from interface:MultiValuedMapReturnstrueif this map contains no key-value mappings.- Specified by:
- isEmptyin interface- MultiValuedMap<K,- V> 
- Returns:
- trueif this map contains no key-value mappings
 
- 
keysDescription copied from interface:MultiValuedMapReturns aMultiSetview of the keys contained in this multivalued map.The MultiSet.getCount(Object)method of the returned multiset will give the same result a callingget(Object).size()for the same key.This multiset is backed by the map, so any changes in the map are reflected in the multiset. - Specified by:
- keysin interface- MultiValuedMap<K,- V> 
- Returns:
- a multiset view of the keys contained in this map
 
- 
keySetDescription copied from interface:MultiValuedMapReturns aSetview of the keys contained in this multivalued map.The set is backed by the map, so changes to the map are reflected in the set, and vice-versa. If the map is modified while an iteration over the set is in progress (except through the iterator's own removeoperation), the result of the iteration is undefined. The set supports element removal, which removes the corresponding mapping from the map, via theIterator.remove,Set.remove,removeAll,retainAll, andclearoperations. It does not support theaddoraddAlloperations.- Specified by:
- keySetin interface- MultiValuedMap<K,- V> 
- Returns:
- a set view of the keys contained in this map
 
- 
mapIteratorDescription copied from interface:MultiValuedMapObtains aMapIteratorover this multivalued map.A map iterator is an efficient way of iterating over maps. There is no need to access the entries collection or use Map.Entryobjects.- Specified by:
- mapIteratorin interface- MultiValuedMap<K,- V> 
- Returns:
- a map iterator
 
- 
putDescription copied from interface:MultiValuedMapAdds a key-value mapping to this multivalued map.Unlike a normal Mapthe previous value is not replaced. Instead, the new value is added to the collection stored against the key. Depending on the collection type used, duplicate key-value mappings may be allowed.The method will return trueif the size of the multivalued map has been increased because of this operation.- Specified by:
- putin interface- MultiValuedMap<K,- V> 
- Parameters:
- key- the key to store against
- value- the value to add to the collection at the key
- Returns:
- true if the map changed as a result of this put operation, or false if the map already contained the key-value mapping and the collection type does not allow duplicate values, for example when using a Set
 
- 
putAllDescription copied from interface:MultiValuedMapAdds a mapping to the specified key for all values contained in the given Iterable.- Specified by:
- putAllin interface- MultiValuedMap<K,- V> 
- Parameters:
- key- the key to store against
- values- the values to add to the collection at the key, may not be null
- Returns:
- true if the map changed as a result of this operation
 
- 
putAllDescription copied from interface:MultiValuedMapCopies all mappings from the specified map to this multivalued map (optional operation).The effect of this call is equivalent to that of calling put(k, v)on this map once for each mapping from keykto valuevin the specified map.The behavior of this operation is undefined if the specified map is modified while the operation is in progress. - Specified by:
- putAllin interface- MultiValuedMap<K,- V> 
- Parameters:
- map- mappings to be stored in this map, may not be null
- Returns:
- true if the map changed as a result of this operation
 
- 
putAllDescription copied from interface:MultiValuedMapCopies all mappings from the specified map to this multivalued map (optional operation).The effect of this call is equivalent to that of calling put(k, v)on this map once for each mapping from keykto valuevin the specified map.The behavior of this operation is undefined if the specified map is modified while the operation is in progress. - Specified by:
- putAllin interface- MultiValuedMap<K,- V> 
- Parameters:
- map- mappings to be stored in this map, may not be null
- Returns:
- true if the map changed as a result of this operation
 
- 
removeDescription copied from interface:MultiValuedMapRemoves all values associated with the specified key.The returned collection may be modifiable, but updates will not be propagated to this multivalued map. In case no mapping was stored for the specified key, an empty, unmodifiable collection will be returned. - Specified by:
- removein interface- MultiValuedMap<K,- V> 
- Parameters:
- key- the key to remove values from
- Returns:
- the values that were removed
 
- 
removeMappingDescription copied from interface:MultiValuedMapRemoves a key-value mapping from the 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 an empty collection from a subsequent get(Object).- Specified by:
- removeMappingin interface- MultiValuedMap<K,- V> 
- Parameters:
- key- the key to remove from
- item- the item to remove
- Returns:
- true if the mapping was removed, false otherwise
 
- 
sizeDescription copied from interface:MultiValuedMapGets the total size of the map.Implementations would return the total size of the map which is the count of the values from all keys. - Specified by:
- sizein interface- MultiValuedMap<K,- V> 
- Returns:
- the total size of the map
 
- 
toString
- 
valuesDescription copied from interface:MultiValuedMapGets aCollectionview of all values contained in this multivalued map.Implementations typically return a collection containing the combination of values from all keys. - Specified by:
- valuesin interface- MultiValuedMap<K,- V> 
- Returns:
- a collection view of the values contained in this multivalued map
 
 
-