Class IdentityHashMapCollectionExtractor
- java.lang.Object
- 
- org.eclipse.mat.internal.collectionextract.FieldArrayCollectionExtractor
- 
- org.eclipse.mat.internal.collectionextract.FieldSizeArrayCollectionExtractor
- 
- org.eclipse.mat.internal.collectionextract.IdentityHashMapCollectionExtractor
 
 
 
- 
- All Implemented Interfaces:
- ICollectionExtractor,- IMapExtractor
 
 public class IdentityHashMapCollectionExtractor extends FieldSizeArrayCollectionExtractor implements IMapExtractor Info for IdentityHashMaps These are stored as key/value pairs in an array
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface org.eclipse.mat.inspections.collectionextract.IMapExtractorIMapExtractor.EntryObject
 
- 
 - 
Constructor SummaryConstructors Constructor Description IdentityHashMapCollectionExtractor(java.lang.String sizeField, java.lang.String arrayField)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description int[]extractEntryIds(IObject idMap)Returns the object ids (int) for all objects which are contained in the collectionjava.util.Iterator<java.util.Map.Entry<IObject,IObject>>extractMapEntries(IObject coll)Extracts the contents of a map (i.e.java.lang.IntegergetCapacity(IObject collection)Gets the capacity of the map.java.lang.DoublegetCollisionRatio(IObject coll)Complete guess as to collision ratio.java.lang.DoublegetFillRatio(IObject coll)Calculate the fill ratio of a collectionjava.lang.IntegergetNumberOfNotNullElements(IObject coll)Returns the number of non-null elements in the collection.java.lang.IntegergetSize(IObject coll)Extract the size of the collection.booleanhasCollisionRatio()Can't calculate the collision ratio as we don't have the identityHashCode for the keys, even if we did know the hash algorithm.booleanhasExtractableArray()Return true if the collection array based and the array can be extracted from the heap dumpbooleanhasExtractableContents()Check if the collection has extractable contents- 
Methods inherited from class org.eclipse.mat.internal.collectionextract.FieldSizeArrayCollectionExtractorhasSize
 - 
Methods inherited from class org.eclipse.mat.internal.collectionextract.FieldArrayCollectionExtractorextractEntries, hasCapacity, hasFillRatio
 - 
Methods inherited from class java.lang.Objectequals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.eclipse.mat.inspections.collectionextract.ICollectionExtractorextractEntries, hasCapacity, hasFillRatio, hasSize
 
- 
 
- 
- 
- 
Method Detail- 
getCapacitypublic java.lang.Integer getCapacity(IObject collection) throws SnapshotException Gets the capacity of the map. Needs two array elements for each entry.- Specified by:
- getCapacityin interface- ICollectionExtractor
- Overrides:
- getCapacityin class- FieldArrayCollectionExtractor
- Parameters:
- collection- - the collection to find the capacity of
- Returns:
- the capacity in bytes, or null if unavailable
- Throws:
- SnapshotException- if there is a problem retrieving data from the snapshot
- See Also:
- ICollectionExtractor.hasCapacity()
 
 - 
hasExtractableArraypublic boolean hasExtractableArray() Description copied from interface:ICollectionExtractorReturn true if the collection array based and the array can be extracted from the heap dump- Specified by:
- hasExtractableArrayin interface- ICollectionExtractor
- Overrides:
- hasExtractableArrayin class- FieldArrayCollectionExtractor
- Returns:
- true if ICollectionExtractor.extractEntries(IObject)could be called
- See Also:
- ICollectionExtractor.extractEntries(IObject)
 
 - 
hasExtractableContentspublic boolean hasExtractableContents() Description copied from interface:ICollectionExtractorCheck if the collection has extractable contents- Specified by:
- hasExtractableContentsin interface- ICollectionExtractor
- Overrides:
- hasExtractableContentsin class- FieldArrayCollectionExtractor
- Returns:
- true if ICollectionExtractor.extractEntryIds(IObject)could be called
- See Also:
- ICollectionExtractor.extractEntryIds(IObject)
 
 - 
getSizepublic java.lang.Integer getSize(IObject coll) throws SnapshotException Description copied from interface:ICollectionExtractorExtract the size of the collection.- Specified by:
- getSizein interface- ICollectionExtractor
- Overrides:
- getSizein class- FieldSizeArrayCollectionExtractor
- Parameters:
- coll- - the collection to find the size of
- Returns:
- the size, or null if not available
- Throws:
- SnapshotException- if there is a problem retrieving data from the snapshot
- See Also:
- ICollectionExtractor.hasSize()
 
 - 
extractEntryIdspublic int[] extractEntryIds(IObject idMap) throws SnapshotException Description copied from interface:ICollectionExtractorReturns the object ids (int) for all objects which are contained in the collection- Specified by:
- extractEntryIdsin interface- ICollectionExtractor
- Overrides:
- extractEntryIdsin class- FieldArrayCollectionExtractor
- Parameters:
- idMap- - the collection to find the objects it holds
- Returns:
- an array of ints which are the object ids.
- Throws:
- SnapshotException- if there is a problem retrieving data from the snapshot
- See Also:
- ICollectionExtractor.hasExtractableContents()
 
 - 
hasCollisionRatiopublic boolean hasCollisionRatio() Can't calculate the collision ratio as we don't have the identityHashCode for the keys, even if we did know the hash algorithm.- Specified by:
- hasCollisionRatioin interface- IMapExtractor
- Returns:
- true if @IMapExtractor.getCollisionRatio(IObject)could be called
- See Also:
- IMapExtractor.getCollisionRatio(IObject)
 
 - 
getCollisionRatiopublic java.lang.Double getCollisionRatio(IObject coll) throws SnapshotException Complete guess as to collision ratio. Look for consecutive entries - perhaps they were caused by a linear probe.- Specified by:
- getCollisionRatioin interface- IMapExtractor
- Parameters:
- coll- - the collection to calculate the collision ratio of
- Returns:
- Double number of elements with colliding keys / size
- Throws:
- SnapshotException
- See Also:
- IMapExtractor.hasCollisionRatio()
 
 - 
getFillRatiopublic java.lang.Double getFillRatio(IObject coll) throws SnapshotException Description copied from interface:ICollectionExtractorCalculate the fill ratio of a collection- Specified by:
- getFillRatioin interface- ICollectionExtractor
- Overrides:
- getFillRatioin class- FieldArrayCollectionExtractor
- Parameters:
- coll- - the collection to find the fill ratio of
- Returns:
- the fill ratio, between 0.0 and 1.0, or null if unavailable
- Throws:
- SnapshotException- if there is a problem retrieving data from the snapshot
- See Also:
- ICollectionExtractor.hasFillRatio()
 
 - 
getNumberOfNotNullElementspublic java.lang.Integer getNumberOfNotNullElements(IObject coll) throws SnapshotException Description copied from interface:ICollectionExtractorReturns the number of non-null elements in the collection. Requires hasExtractableContents or hasExtractableArray- Specified by:
- getNumberOfNotNullElementsin interface- ICollectionExtractor
- Overrides:
- getNumberOfNotNullElementsin class- FieldArrayCollectionExtractor
- Parameters:
- coll- - the collection to find the number of non-null content objects
- Returns:
- the number of non-null elements, or null if not available
- Throws:
- SnapshotException
- See Also:
- ICollectionExtractor.hasExtractableContents(),- ICollectionExtractor.hasExtractableArray()
 
 - 
extractMapEntriespublic java.util.Iterator<java.util.Map.Entry<IObject,IObject>> extractMapEntries(IObject coll) throws SnapshotException Description copied from interface:IMapExtractorExtracts the contents of a map (i.e. an IObject representing a Map) and provides an Iterator over them- Specified by:
- extractMapEntriesin interface- IMapExtractor
- Parameters:
- coll- - the map to extract contents from
- Returns:
- an Iterator over the entries. If the original Map had an Entry object, the content of the iterator would usually be EntryObject
- Throws:
- SnapshotException
 
 
- 
 
-