net.aavalla.utils.general
Class RetrievalAbstractMap<K,V>

java.lang.Object
  extended by net.aavalla.utils.general.RetrievalAbstractMap<K,V>
All Implemented Interfaces:
java.util.Map<K,V>
Direct Known Subclasses:
RetrievalHashMap

public abstract class RetrievalAbstractMap<K,V>
extends java.lang.Object
implements java.util.Map<K,V>

This class is an abstract implementation of the Map interface. This implementation does not support adding. A subclass must implement the abstract method entrySet().

Since:
1.2

Nested Class Summary
 
Nested classes/interfaces inherited from interface java.util.Map
java.util.Map.Entry<K,V>
 
Constructor Summary
protected RetrievalAbstractMap()
          Constructs a new instance of this AbstractMap.
 
Method Summary
 void clear()
          Removes all elements from this map, leaving it empty.
protected  java.lang.Object clone()
          Returns a new instance of the same class as this instance, whose slots have been filled in with the values of the slots of this instance.
 boolean containsKey(java.lang.Object key)
          Returns whether this map contains the specified key.
 boolean containsValue(java.lang.Object value)
          Returns whether this map contains the specified value.
abstract  java.util.Set<java.util.Map.Entry<K,V>> entrySet()
          Returns a set containing all of the mappings in this map.
 boolean equals(java.lang.Object object)
          Compares the specified object to this instance, and returns true if the specified object is a map and both maps contain the same mappings.
 V get(java.lang.Object key)
          Returns the value of the mapping with the specified key.
 int hashCode()
          Returns the hash code for this object.
 boolean isEmpty()
          Returns whether this map is empty.
 java.util.Set<K> keySet()
          Returns a set of the keys contained in this map.
 V put(K key, V value)
          Maps the specified key to the specified value.
 void putAll(java.util.Map<? extends K,? extends V> map)
          Copies every mapping in the specified map to this map.
 V remove(java.lang.Object key)
          Removes a mapping with the specified key from this Map.
 int size()
          Returns the number of elements in this map.
 java.lang.String toString()
          Returns the string representation of this map.
 java.util.Collection<V> values()
          Returns a collection of the values contained in this map.
 
Methods inherited from class java.lang.Object
finalize, getClass, notify, notifyAll, wait, wait, wait
 

Constructor Detail

RetrievalAbstractMap

protected RetrievalAbstractMap()
Constructs a new instance of this AbstractMap.

Method Detail

clear

public void clear()
Removes all elements from this map, leaving it empty.

Specified by:
clear in interface java.util.Map<K,V>
Throws:
java.lang.UnsupportedOperationException - if removing from this map is not supported.
See Also:
isEmpty(), size()

containsKey

public boolean containsKey(java.lang.Object key)
Returns whether this map contains the specified key.

Specified by:
containsKey in interface java.util.Map<K,V>
Parameters:
key - the key to search for.
Returns:
true if this map contains the specified key, false otherwise.

containsValue

public boolean containsValue(java.lang.Object value)
Returns whether this map contains the specified value.

Specified by:
containsValue in interface java.util.Map<K,V>
Parameters:
value - the value to search for.
Returns:
true if this map contains the specified value, false otherwise.

entrySet

public abstract java.util.Set<java.util.Map.Entry<K,V>> entrySet()
Returns a set containing all of the mappings in this map. Each mapping is an instance of Map.Entry. As the set is backed by this map, changes in one will be reflected in the other.

Specified by:
entrySet in interface java.util.Map<K,V>
Returns:
a set of the mappings.

equals

public boolean equals(java.lang.Object object)
Compares the specified object to this instance, and returns true if the specified object is a map and both maps contain the same mappings.

Specified by:
equals in interface java.util.Map<K,V>
Overrides:
equals in class java.lang.Object
Parameters:
object - the object to compare with this object.
Returns:
boolean true if the object is the same as this object, and false if it is different from this object.
See Also:
hashCode(), entrySet()

get

public V get(java.lang.Object key)
Returns the value of the mapping with the specified key.

Specified by:
get in interface java.util.Map<K,V>
Parameters:
key - the key.
Returns:
the value of the mapping with the specified key, or null if no mapping for the specified key is found.

hashCode

public int hashCode()
Returns the hash code for this object. Objects which are equal must return the same value for this method.

Specified by:
hashCode in interface java.util.Map<K,V>
Overrides:
hashCode in class java.lang.Object
Returns:
the hash code of this object.
See Also:
equals(Object)

isEmpty

public boolean isEmpty()
Returns whether this map is empty.

Specified by:
isEmpty in interface java.util.Map<K,V>
Returns:
true if this map has no elements, false otherwise.
See Also:
size()

keySet

public java.util.Set<K> keySet()
Returns a set of the keys contained in this map. The set is backed by this map so changes to one are reflected by the other. The returned set does not support adding.

Specified by:
keySet in interface java.util.Map<K,V>
Returns:
a set of the keys.

put

public V put(K key,
             V value)
Maps the specified key to the specified value.

Specified by:
put in interface java.util.Map<K,V>
Parameters:
key - the key.
value - the value.
Returns:
the value of any previous mapping with the specified key or null if there was no mapping.
Throws:
java.lang.UnsupportedOperationException - if adding to this map is not supported.
java.lang.ClassCastException - if the class of the key or value is inappropriate for this map.
java.lang.IllegalArgumentException - if the key or value cannot be added to this map.
java.lang.NullPointerException - if the key or value is null and this Map does not support null keys or values.

putAll

public void putAll(java.util.Map<? extends K,? extends V> map)
Copies every mapping in the specified map to this map.

Specified by:
putAll in interface java.util.Map<K,V>
Parameters:
map - the map to copy mappings from.
Throws:
java.lang.UnsupportedOperationException - if adding to this map is not supported.
java.lang.ClassCastException - if the class of a key or value is inappropriate for this map.
java.lang.IllegalArgumentException - if a key or value cannot be added to this map.
java.lang.NullPointerException - if a key or value is null and this map does not support null keys or values.

remove

public V remove(java.lang.Object key)
Removes a mapping with the specified key from this Map.

Specified by:
remove in interface java.util.Map<K,V>
Parameters:
key - the key of the mapping to remove.
Returns:
the value of the removed mapping or null if no mapping for the specified key was found.
Throws:
java.lang.UnsupportedOperationException - if removing from this map is not supported.

size

public int size()
Returns the number of elements in this map.

Specified by:
size in interface java.util.Map<K,V>
Returns:
the number of elements in this map.

toString

public java.lang.String toString()
Returns the string representation of this map.

Overrides:
toString in class java.lang.Object
Returns:
the string representation of this map.

values

public java.util.Collection<V> values()
Returns a collection of the values contained in this map. The collection is backed by this map so changes to one are reflected by the other. The collection supports remove, removeAll, retainAll and clear operations, and it does not support add or addAll operations.

This method returns a collection which is the subclass of AbstractCollection. The iterator method of this subclass returns a "wrapper object" over the iterator of map's entrySet(). The size method wraps the map's size method and the contains method wraps the map's containsValue method.

The collection is created when this method is called for the first time and returned in response to all subsequent calls. This method may return different collections when multiple concurrent calls occur to this method, since no synchronization is performed.

Specified by:
values in interface java.util.Map<K,V>
Returns:
a collection of the values contained in this map.

clone

protected java.lang.Object clone()
                          throws java.lang.CloneNotSupportedException
Returns a new instance of the same class as this instance, whose slots have been filled in with the values of the slots of this instance.

Overrides:
clone in class java.lang.Object
Returns:
a shallow copy of this object.
Throws:
java.lang.CloneNotSupportedException - if the receiver's class does not implement the interface Cloneable.