Package org.eclipse.mat.snapshot
Class MultiplePathsFromGCRootsRecord
- java.lang.Object
- 
- org.eclipse.mat.snapshot.MultiplePathsFromGCRootsRecord
 
- 
 public class MultiplePathsFromGCRootsRecord extends java.lang.ObjectThis class represents a set of paths from the GC roots to different objects, which go through one and the same object.
- 
- 
Constructor SummaryConstructors Constructor Description MultiplePathsFromGCRootsRecord(int objectId, int level, ISnapshot snapshot)A constructor to create the record
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddPath(int[] path)This method is used only when the record is built.static java.util.Comparator<MultiplePathsFromGCRootsRecord>getComparatorByNumberOfReferencedObjects()Returns a Comparator ordering the records descending by the number of referenced objects.static java.util.Comparator<MultiplePathsFromGCRootsRecord>getComparatorByReferencedHeapSize()Returns a Comparator ordering the records descending by the total size of referenced objects.static java.util.Comparator<MultiplePathsFromGCRootsRecord>getComparatorByReferencedRetainedSize()Returns a Comparator ordering the records descending by the total size of referenced objects.intgetCount()Get the number of paths going through this objectintgetLevel()Get the level of this recordintgetObjectId()Get the id of the object which is common for all the pathsjava.util.List<int[]>getPaths()Get all the paths going through the object (getObjectId())longgetReferencedHeapSize()Get the total net heap size of all referenced objects (see getReferencedObjects())int[]getReferencedObjects()Get the "end" objects for each path.longgetReferencedRetainedSize()Get the total retained heap size of the referenced objectsMultiplePathsFromGCRootsRecord[]nextLevel()Returns the next level of the paths.voidsetReferencedRetainedSize(long referencedRetainedSize)Set the retained heap size of the referenced objects
 
- 
- 
- 
Constructor Detail- 
MultiplePathsFromGCRootsRecordpublic MultiplePathsFromGCRootsRecord(int objectId, int level, ISnapshot snapshot)A constructor to create the record- Parameters:
- objectId- - the ID of the object which is common for all the paths
- level- - the level (depth) in the paths where this objects appears
- snapshot- - an ISnapshot object used for further calculation
 
 
- 
 - 
Method Detail- 
getReferencedRetainedSizepublic long getReferencedRetainedSize() Get the total retained heap size of the referenced objects
 - 
setReferencedRetainedSizepublic void setReferencedRetainedSize(long referencedRetainedSize) Set the retained heap size of the referenced objects
 - 
nextLevelpublic MultiplePathsFromGCRootsRecord[] nextLevel() Returns the next level of the paths. For all paths going through this object the next objects in the paths are taken and grouped again (i.e. the lenght of the returned array will be equal to the number of different objects at the next depth level of the paths). The direction is from the GC roots to the objects- Returns:
- MultiplePathsFromGCRootsRecord[] Each record in the result represents again paths going through one and the same object
 
 - 
addPathpublic void addPath(int[] path) This method is used only when the record is built. Adds one path to the set of paths- Parameters:
- path-
 
 - 
getPathspublic java.util.List<int[]> getPaths() Get all the paths going through the object (getObjectId())- Returns:
- List<int[]> each element in the list is an int[] representing a path
 
 - 
getObjectIdpublic int getObjectId() Get the id of the object which is common for all the paths
 - 
getCountpublic int getCount() Get the number of paths going through this object
 - 
getLevelpublic int getLevel() Get the level of this record
 - 
getReferencedObjectspublic int[] getReferencedObjects() Get the "end" objects for each path. This is equal to getting all the paths and looking at their element [0]- Returns:
- - an array with all the objects at the end of the paths
 
 - 
getReferencedHeapSizepublic long getReferencedHeapSize() throws SnapshotExceptionGet the total net heap size of all referenced objects (see getReferencedObjects())- Returns:
- - the total heap size of all referenced objects
- Throws:
- SnapshotException
 
 - 
getComparatorByNumberOfReferencedObjectspublic static java.util.Comparator<MultiplePathsFromGCRootsRecord> getComparatorByNumberOfReferencedObjects() Returns a Comparator ordering the records descending by the number of referenced objects.
 - 
getComparatorByReferencedHeapSizepublic static java.util.Comparator<MultiplePathsFromGCRootsRecord> getComparatorByReferencedHeapSize() Returns a Comparator ordering the records descending by the total size of referenced objects.
 - 
getComparatorByReferencedRetainedSizepublic static java.util.Comparator<MultiplePathsFromGCRootsRecord> getComparatorByReferencedRetainedSize() Returns a Comparator ordering the records descending by the total size of referenced objects.
 
- 
 
-