com.google.common.collect
Class MutableClassToInstanceMap<B>

java.lang.Object
  extended by com.google.common.collect.ForwardingObject
      extended by com.google.common.collect.ForwardingMap<K,V>
          extended by com.google.common.collect.MutableClassToInstanceMap<B>
All Implemented Interfaces:
ClassToInstanceMap<B>, Map<Class<? extends B>,B>

public final class MutableClassToInstanceMap<B>
extends ForwardingMap<K,V>
implements ClassToInstanceMap<B>

A mutable class-to-instance map backed by an arbitrary user-provided map. See also ImmutableClassToInstanceMap.

See the Guava User Guide article on ClassToInstanceMap.

Since:
2.0 (imported from Google Collections Library)
Author:
Kevin Bourrillion

Nested Class Summary
 
Nested classes/interfaces inherited from class com.google.common.collect.ForwardingMap
ForwardingMap.StandardEntrySet, ForwardingMap.StandardKeySet, ForwardingMap.StandardValues
 
Nested classes/interfaces inherited from interface java.util.Map
Map.Entry<K,V>
 
Method Summary
static
<B> MutableClassToInstanceMap<B>
create()
          Returns a new MutableClassToInstanceMap instance backed by a HashMap using the default initial capacity and load factor.
static
<B> MutableClassToInstanceMap<B>
create(Map<Class<? extends B>,B> backingMap)
          Returns a new MutableClassToInstanceMap instance backed by a given empty backingMap.
protected  Map<K,V> delegate()
          Returns the backing delegate instance that methods are forwarded to.
 Set<Map.Entry<K,V>> entrySet()
           
<T extends B>
T
getInstance(Class<T> type)
          Returns the value the specified class is mapped to, or null if no entry for this class is present.
 V put(K key, V value)
           
 void putAll(Map<? extends K,? extends V> map)
           
<T extends B>
T
putInstance(Class<T> type, T value)
          Maps the specified class to the specified value.
 
Methods inherited from class com.google.common.collect.ForwardingMap
clear, containsKey, containsValue, equals, get, hashCode, isEmpty, keySet, remove, size, standardClear, standardContainsKey, standardContainsValue, standardEquals, standardHashCode, standardIsEmpty, standardPutAll, standardRemove, standardToString, values
 
Methods inherited from class com.google.common.collect.ForwardingObject
toString
 
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
 
Methods inherited from interface java.util.Map
clear, containsKey, containsValue, entrySet, equals, get, hashCode, isEmpty, keySet, put, putAll, remove, size, values
 

Method Detail

create

public static <B> MutableClassToInstanceMap<B> create()
Returns a new MutableClassToInstanceMap instance backed by a HashMap using the default initial capacity and load factor.


create

public static <B> MutableClassToInstanceMap<B> create(Map<Class<? extends B>,B> backingMap)
Returns a new MutableClassToInstanceMap instance backed by a given empty backingMap. The caller surrenders control of the backing map, and thus should not allow any direct references to it to remain accessible.


putInstance

public <T extends B> T putInstance(Class<T> type,
                                   T value)
Description copied from interface: ClassToInstanceMap
Maps the specified class to the specified value. Does not associate this value with any of the class's supertypes.

Specified by:
putInstance in interface ClassToInstanceMap<B>
Returns:
the value previously associated with this class (possibly null), or null if there was no previous entry.

getInstance

public <T extends B> T getInstance(Class<T> type)
Description copied from interface: ClassToInstanceMap
Returns the value the specified class is mapped to, or null if no entry for this class is present. This will only return a value that was bound to this specific class, not a value that may have been bound to a subtype.

Specified by:
getInstance in interface ClassToInstanceMap<B>

delegate

protected Map<K,V> delegate()
Description copied from class: ForwardingObject
Returns the backing delegate instance that methods are forwarded to. Abstract subclasses generally override this method with an abstract method that has a more specific return type, such as ForwardingSet.delegate(). Concrete subclasses override this method to supply the instance being decorated.

Specified by:
delegate in class ForwardingMap<K,V>

entrySet

public Set<Map.Entry<K,V>> entrySet()
Specified by:
entrySet in interface Map<K,V>
Overrides:
entrySet in class ForwardingMap<K,V>

put

public V put(K key,
             V value)
Specified by:
put in interface Map<K,V>
Overrides:
put in class ForwardingMap<K,V>

putAll

public void putAll(Map<? extends K,? extends V> map)
Specified by:
putAll in interface Map<K,V>
Overrides:
putAll in class ForwardingMap<K,V>


Copyright © 2010-2012. All Rights Reserved.