Java Doc for AbstractReferenceMap.java in  » Library » Apache-common-Collections » org » apache » commons » collections » map » Java Source Code / Java DocumentationJava Source Code and Java Documentation

Java Source Code / Java Documentation
1. 6.0 JDK Core
2. 6.0 JDK Modules
3. 6.0 JDK Modules com.sun
4. 6.0 JDK Modules com.sun.java
5. 6.0 JDK Modules sun
6. 6.0 JDK Platform
7. Ajax
8. Apache Harmony Java SE
9. Aspect oriented
10. Authentication Authorization
11. Blogger System
12. Build
13. Byte Code
14. Cache
15. Chart
16. Chat
17. Code Analyzer
18. Collaboration
19. Content Management System
20. Database Client
21. Database DBMS
22. Database JDBC Connection Pool
23. Database ORM
24. Development
25. EJB Server geronimo
26. EJB Server GlassFish
27. EJB Server JBoss 4.2.1
28. EJB Server resin 3.1.5
29. ERP CRM Financial
30. ESB
31. Forum
32. GIS
33. Graphic Library
34. Groupware
35. HTML Parser
36. IDE
37. IDE Eclipse
38. IDE Netbeans
39. Installer
40. Internationalization Localization
41. Inversion of Control
42. Issue Tracking
43. J2EE
44. JBoss
45. JMS
46. JMX
47. Library
48. Mail Clients
49. Net
50. Parser
51. PDF
52. Portal
53. Profiler
54. Project Management
55. Report
56. RSS RDF
57. Rule Engine
58. Science
59. Scripting
60. Search Engine
61. Security
62. Sevlet Container
63. Source Control
64. Swing Library
65. Template Engine
66. Test Coverage
67. Testing
68. UML
69. Web Crawler
70. Web Framework
71. Web Mail
72. Web Server
73. Web Services
74. Web Services apache cxf 2.0.1
75. Web Services AXIS2
76. Wiki Engine
77. Workflow Engines
78. XML
79. XML UI
Java
Java Tutorial
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
Photoshop Tutorials
Maya Tutorials
Flash Tutorials
3ds-Max Tutorials
Illustrator Tutorials
GIMP Tutorials
C# / C Sharp
C# / CSharp Tutorial
C# / CSharp Open Source
ASP.Net
ASP.NET Tutorial
JavaScript DHTML
JavaScript Tutorial
JavaScript Reference
HTML / CSS
HTML CSS Reference
C / ANSI-C
C Tutorial
C++
C++ Tutorial
Ruby
PHP
Python
Python Tutorial
Python Open Source
SQL Server / T-SQL
SQL Server / T-SQL Tutorial
Oracle PL / SQL
Oracle PL/SQL Tutorial
PostgreSQL
SQL / MySQL
MySQL Tutorial
VB.Net
VB.Net Tutorial
Flash / Flex / ActionScript
VBA / Excel / Access / Word
XML
XML Tutorial
Microsoft Office PowerPoint 2007 Tutorial
Microsoft Office Excel 2007 Tutorial
Microsoft Office Word 2007 Tutorial
Java Source Code / Java Documentation » Library » Apache common Collections » org.apache.commons.collections.map 
Source Cross Reference  Class Diagram Java Document (Java Doc) 


org.apache.commons.collections.map.AbstractHashedMap
   org.apache.commons.collections.map.AbstractReferenceMap

All known Subclasses:   org.apache.commons.collections.map.ReferenceIdentityMap,  org.apache.commons.collections.map.ReferenceMap,
AbstractReferenceMap
abstract public class AbstractReferenceMap extends AbstractHashedMap (Code)
An abstract implementation of a hash-based map that allows the entries to be removed by the garbage collector.

This class implements all the features necessary for a subclass reference hash-based map. Key-value entries are stored in instances of the ReferenceEntry class which can be overridden and replaced. The iterators can similarly be replaced, without the need to replace the KeySet, EntrySet and Values view classes.

Overridable methods are provided to change the default hashing behaviour, and to change how entries are added to and removed from the map. Hopefully, all you need for unusual subclasses is here.

When you construct an AbstractReferenceMap, you can specify what kind of references are used to store the map's keys and values. If non-hard references are used, then the garbage collector can remove mappings if a key or value becomes unreachable, or if the JVM's memory is running low. For information on how the different reference types behave, see Reference .

Different types of references can be specified for keys and values. The keys can be configured to be weak but the values hard, in which case this class will behave like a WeakHashMap. However, you can also specify hard keys and weak values, or any other combination. The default constructor uses hard keys and soft values, providing a memory-sensitive cache.

This Map implementation does not allow null elements. Attempting to add a null key or value to the map will raise a NullPointerException.

All the available iterators can be reset back to the start by casting to ResettableIterator and calling reset().

This implementation is not synchronized. You can use java.util.Collections.synchronizedMap to provide synchronized access to a ReferenceMap.
See Also:   java.lang.ref.Reference
since:
   Commons Collections 3.1 (extracted from ReferenceMap in 3.0)
version:
   $Revision: 155406 $ $Date: 2005-02-26 12:55:26 +0000 (Sat, 26 Feb 2005) $
author:
   Paul Jack
author:
   Stephen Colebourne


Inner Class :static class ReferenceEntrySet extends EntrySet
Inner Class :static class ReferenceKeySet extends KeySet
Inner Class :static class ReferenceValues extends Values
Inner Class :protected static class ReferenceEntry extends HashEntry
Inner Class :static class ReferenceEntrySetIterator implements Iterator
Inner Class :static class ReferenceKeySetIterator extends ReferenceEntrySetIterator
Inner Class :static class ReferenceValuesIterator extends ReferenceEntrySetIterator
Inner Class :static class ReferenceMapIterator extends ReferenceEntrySetIterator implements MapIterator
Inner Class :static class SoftRef extends SoftReference
Inner Class :static class WeakRef extends WeakReference

Field Summary
final public static  intHARD
    
final public static  intSOFT
    
final public static  intWEAK
    
protected  intkeyType
     The reference type for keys.
protected  booleanpurgeValues
    
protected  intvalueType
     The reference type for values.

Constructor Summary
protected  AbstractReferenceMap()
     Constructor used during deserialization.
protected  AbstractReferenceMap(int keyType, int valueType, int capacity, float loadFactor, boolean purgeValues)
     Constructs a new empty map with the specified reference types, load factor and initial capacity.

Method Summary
public  voidclear()
     Clears this map.
public  booleancontainsKey(Object key)
     Checks whether the map contains the specified key.
public  booleancontainsValue(Object value)
     Checks whether the map contains the specified value.
protected  HashEntrycreateEntry(HashEntry next, int hashCode, Object key, Object value)
     Creates a ReferenceEntry instead of a HashEntry.
protected  IteratorcreateEntrySetIterator()
     Creates an entry set iterator.
protected  IteratorcreateKeySetIterator()
     Creates an key set iterator.
protected  IteratorcreateValuesIterator()
     Creates an values iterator.
protected  voiddoReadObject(ObjectInputStream in)
     Replaces the superclassm method to read the state of this class.

Serialization is not one of the JDK's nicest topics.

protected  voiddoWriteObject(ObjectOutputStream out)
     Replaces the superclass method to store the state of this class.

Serialization is not one of the JDK's nicest topics.

public  SetentrySet()
     Returns a set view of this map's entries.
public  Objectget(Object key)
     Gets the value mapped to the key specified.
protected  HashEntrygetEntry(Object key)
     Gets the entry mapped to the key specified.
protected  inthashEntry(Object key, Object value)
     Gets the hash code for a MapEntry.
protected  voidinit()
     Initialise this subclass during construction, cloning or deserialization.
public  booleanisEmpty()
     Checks whether the map is currently empty.
protected  booleanisEqualKey(Object key1, Object key2)
     Compares two keys, in internal converted form, to see if they are equal.
public  SetkeySet()
     Returns a set view of this map's keys.
public  MapIteratormapIterator()
     Gets a MapIterator over the reference map.
protected  voidpurge()
     Purges stale mappings from this map.
protected  voidpurge(Reference ref)
     Purges the specified reference.
protected  voidpurgeBeforeRead()
     Purges stale mappings from this map before read operations.
protected  voidpurgeBeforeWrite()
     Purges stale mappings from this map before write operations.
public  Objectput(Object key, Object value)
     Puts a key-value mapping into this map.
public  Objectremove(Object key)
     Removes the specified mapping from this map.
public  intsize()
     Gets the size of the map.
public  Collectionvalues()
     Returns a collection view of this map's values.

Field Detail
HARD
final public static int HARD(Code)
Constant indicating that hard references should be used



SOFT
final public static int SOFT(Code)
Constant indicating that soft references should be used



WEAK
final public static int WEAK(Code)
Constant indicating that weak references should be used



keyType
protected int keyType(Code)
The reference type for keys. Must be HARD, SOFT, WEAK.



purgeValues
protected boolean purgeValues(Code)
Should the value be automatically purged when the associated key has been collected?



valueType
protected int valueType(Code)
The reference type for values. Must be HARD, SOFT, WEAK.




Constructor Detail
AbstractReferenceMap
protected AbstractReferenceMap()(Code)
Constructor used during deserialization.



AbstractReferenceMap
protected AbstractReferenceMap(int keyType, int valueType, int capacity, float loadFactor, boolean purgeValues)(Code)
Constructs a new empty map with the specified reference types, load factor and initial capacity.
Parameters:
  keyType - the type of reference to use for keys;must be AbstractReferenceMap.HARD, AbstractReferenceMap.SOFT, AbstractReferenceMap.WEAK
Parameters:
  valueType - the type of reference to use for values;must be AbstractReferenceMap.HARD, AbstractReferenceMap.SOFT, AbstractReferenceMap.WEAK
Parameters:
  capacity - the initial capacity for the map
Parameters:
  loadFactor - the load factor for the map
Parameters:
  purgeValues - should the value be automatically purged when the key is garbage collected




Method Detail
clear
public void clear()(Code)
Clears this map.



containsKey
public boolean containsKey(Object key)(Code)
Checks whether the map contains the specified key.
Parameters:
  key - the key to search for true if the map contains the key



containsValue
public boolean containsValue(Object value)(Code)
Checks whether the map contains the specified value.
Parameters:
  value - the value to search for true if the map contains the value



createEntry
protected HashEntry createEntry(HashEntry next, int hashCode, Object key, Object value)(Code)
Creates a ReferenceEntry instead of a HashEntry.
Parameters:
  next - the next entry in sequence
Parameters:
  hashCode - the hash code to use
Parameters:
  key - the key to store
Parameters:
  value - the value to store the newly created entry



createEntrySetIterator
protected Iterator createEntrySetIterator()(Code)
Creates an entry set iterator. the entrySet iterator



createKeySetIterator
protected Iterator createKeySetIterator()(Code)
Creates an key set iterator. the keySet iterator



createValuesIterator
protected Iterator createValuesIterator()(Code)
Creates an values iterator. the values iterator



doReadObject
protected void doReadObject(ObjectInputStream in) throws IOException, ClassNotFoundException(Code)
Replaces the superclassm method to read the state of this class.

Serialization is not one of the JDK's nicest topics. Normal serialization will initialise the superclass before the subclass. Sometimes however, this isn't what you want, as in this case the put() method on read can be affected by subclass state.

The solution adopted here is to deserialize the state data of this class in this protected method. This method must be called by the readObject() of the first serializable subclass.

Subclasses may override if the subclass has a specific field that must be present before put() or calculateThreshold() will work correctly.
Parameters:
  in - the input stream




doWriteObject
protected void doWriteObject(ObjectOutputStream out) throws IOException(Code)
Replaces the superclass method to store the state of this class.

Serialization is not one of the JDK's nicest topics. Normal serialization will initialise the superclass before the subclass. Sometimes however, this isn't what you want, as in this case the put() method on read can be affected by subclass state.

The solution adopted here is to serialize the state data of this class in this protected method. This method must be called by the writeObject() of the first serializable subclass.

Subclasses may override if they have a specific field that must be present on read before this implementation will work. Generally, the read determines what must be serialized here, if anything.
Parameters:
  out - the output stream




entrySet
public Set entrySet()(Code)
Returns a set view of this map's entries. An iterator returned entry is valid until next() is called again. The setValue() method on the toArray entries has no effect. a set view of this map's entries



get
public Object get(Object key)(Code)
Gets the value mapped to the key specified.
Parameters:
  key - the key the mapped value, null if no match



getEntry
protected HashEntry getEntry(Object key)(Code)
Gets the entry mapped to the key specified.
Parameters:
  key - the key the entry, null if no match



hashEntry
protected int hashEntry(Object key, Object value)(Code)
Gets the hash code for a MapEntry. Subclasses can override this, for example to use the identityHashCode.
Parameters:
  key - the key to get a hash code for, may be null
Parameters:
  value - the value to get a hash code for, may be null the hash code, as per the MapEntry specification



init
protected void init()(Code)
Initialise this subclass during construction, cloning or deserialization.



isEmpty
public boolean isEmpty()(Code)
Checks whether the map is currently empty. true if the map is currently size zero



isEqualKey
protected boolean isEqualKey(Object key1, Object key2)(Code)
Compares two keys, in internal converted form, to see if they are equal.

This implementation converts the key from the entry to a real reference before comparison.
Parameters:
  key1 - the first key to compare passed in from outside
Parameters:
  key2 - the second key extracted from the entry via entry.key true if equal




keySet
public Set keySet()(Code)
Returns a set view of this map's keys. a set view of this map's keys



mapIterator
public MapIterator mapIterator()(Code)
Gets a MapIterator over the reference map. The iterator only returns valid key/value pairs. a map iterator



purge
protected void purge()(Code)
Purges stale mappings from this map.

Note that this method is not synchronized! Special care must be taken if, for instance, you want stale mappings to be removed on a periodic basis by some background thread.




purge
protected void purge(Reference ref)(Code)
Purges the specified reference.
Parameters:
  ref - the reference to purge



purgeBeforeRead
protected void purgeBeforeRead()(Code)
Purges stale mappings from this map before read operations.

This implementation calls AbstractReferenceMap.purge() to maintain a consistent state.




purgeBeforeWrite
protected void purgeBeforeWrite()(Code)
Purges stale mappings from this map before write operations.

This implementation calls AbstractReferenceMap.purge() to maintain a consistent state.




put
public Object put(Object key, Object value)(Code)
Puts a key-value mapping into this map. Neither the key nor the value may be null.
Parameters:
  key - the key to add, must not be null
Parameters:
  value - the value to add, must not be null the value previously mapped to this key, null if none
throws:
  NullPointerException - if either the key or value is null



remove
public Object remove(Object key)(Code)
Removes the specified mapping from this map.
Parameters:
  key - the mapping to remove the value mapped to the removed key, null if key not in map



size
public int size()(Code)
Gets the size of the map. the size



values
public Collection values()(Code)
Returns a collection view of this map's values. a set view of this map's values



Fields inherited from org.apache.commons.collections.map.AbstractHashedMap
final protected static int DEFAULT_CAPACITY(Code)(Java Doc)
final protected static float DEFAULT_LOAD_FACTOR(Code)(Java Doc)
final protected static int DEFAULT_THRESHOLD(Code)(Java Doc)
final protected static String GETKEY_INVALID(Code)(Java Doc)
final protected static String GETVALUE_INVALID(Code)(Java Doc)
final protected static int MAXIMUM_CAPACITY(Code)(Java Doc)
final protected static String NO_NEXT_ENTRY(Code)(Java Doc)
final protected static String NO_PREVIOUS_ENTRY(Code)(Java Doc)
final protected static Object NULL(Code)(Java Doc)
final protected static String REMOVE_INVALID(Code)(Java Doc)
final protected static String SETVALUE_INVALID(Code)(Java Doc)
protected transient HashEntry[] data(Code)(Java Doc)
protected transient EntrySet entrySet(Code)(Java Doc)
protected transient KeySet keySet(Code)(Java Doc)
protected transient float loadFactor(Code)(Java Doc)
protected transient int modCount(Code)(Java Doc)
protected transient int size(Code)(Java Doc)
protected transient int threshold(Code)(Java Doc)
protected transient Values values(Code)(Java Doc)

Methods inherited from org.apache.commons.collections.map.AbstractHashedMap
protected void addEntry(HashEntry entry, int hashIndex)(Code)(Java Doc)
protected void addMapping(int hashIndex, int hashCode, Object key, Object value)(Code)(Java Doc)
protected int calculateNewCapacity(int proposedCapacity)(Code)(Java Doc)
protected int calculateThreshold(int newCapacity, float factor)(Code)(Java Doc)
protected void checkCapacity()(Code)(Java Doc)
public void clear()(Code)(Java Doc)
protected Object clone()(Code)(Java Doc)
public boolean containsKey(Object key)(Code)(Java Doc)
public boolean containsValue(Object value)(Code)(Java Doc)
protected Object convertKey(Object key)(Code)(Java Doc)
protected HashEntry createEntry(HashEntry next, int hashCode, Object key, Object value)(Code)(Java Doc)
protected Iterator createEntrySetIterator()(Code)(Java Doc)
protected Iterator createKeySetIterator()(Code)(Java Doc)
protected Iterator createValuesIterator()(Code)(Java Doc)
protected void destroyEntry(HashEntry entry)(Code)(Java Doc)
protected void doReadObject(ObjectInputStream in) throws IOException, ClassNotFoundException(Code)(Java Doc)
protected void doWriteObject(ObjectOutputStream out) throws IOException(Code)(Java Doc)
protected void ensureCapacity(int newCapacity)(Code)(Java Doc)
protected int entryHashCode(HashEntry entry)(Code)(Java Doc)
protected Object entryKey(HashEntry entry)(Code)(Java Doc)
protected HashEntry entryNext(HashEntry entry)(Code)(Java Doc)
public Set entrySet()(Code)(Java Doc)
protected Object entryValue(HashEntry entry)(Code)(Java Doc)
public boolean equals(Object obj)(Code)(Java Doc)
public Object get(Object key)(Code)(Java Doc)
protected HashEntry getEntry(Object key)(Code)(Java Doc)
protected int hash(Object key)(Code)(Java Doc)
public int hashCode()(Code)(Java Doc)
protected int hashIndex(int hashCode, int dataSize)(Code)(Java Doc)
protected void init()(Code)(Java Doc)
public boolean isEmpty()(Code)(Java Doc)
protected boolean isEqualKey(Object key1, Object key2)(Code)(Java Doc)
protected boolean isEqualValue(Object value1, Object value2)(Code)(Java Doc)
public Set keySet()(Code)(Java Doc)
public MapIterator mapIterator()(Code)(Java Doc)
public Object put(Object key, Object value)(Code)(Java Doc)
public void putAll(Map map)(Code)(Java Doc)
public Object remove(Object key)(Code)(Java Doc)
protected void removeEntry(HashEntry entry, int hashIndex, HashEntry previous)(Code)(Java Doc)
protected void removeMapping(HashEntry entry, int hashIndex, HashEntry previous)(Code)(Java Doc)
protected void reuseEntry(HashEntry entry, int hashIndex, int hashCode, Object key, Object value)(Code)(Java Doc)
public int size()(Code)(Java Doc)
public String toString()(Code)(Java Doc)
protected void updateEntry(HashEntry entry, Object newValue)(Code)(Java Doc)
public Collection values()(Code)(Java Doc)

www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.