Package org.eclipse.mat.parser.model
Class ClassImpl
java.lang.Object
org.eclipse.mat.parser.model.AbstractObjectImpl
org.eclipse.mat.parser.model.ClassImpl
- All Implemented Interfaces:
- Serializable,- Comparable<ClassImpl>,- IClass,- IObject
Implementation of a Java object representing a java.lang.Class object.
 As well as some standard object information it contains information about the class
 and summary details about instances of this class.
- See Also:
- No Extend:
- 
Nested Class SummaryNested classes/interfaces inherited from interface org.eclipse.mat.snapshot.model.IObjectIObject.Type
- 
Field SummaryFieldsFields inherited from interface org.eclipse.mat.snapshot.model.IClassJAVA_LANG_CLASSLOADER
- 
Constructor SummaryConstructorsConstructorDescriptionClassImpl(long address, String name, long superAddress, long loaderAddress, Field[] staticFields, FieldDescriptor[] fields) Construct a class object based on name, address and fields.
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddInstance(long usedHeapSize) Note another instance to this class.voidaddSubClass(ClassImpl clazz) Add a subclass of this class.intbooleandoesExtend(String className) Does this class extend a class of the supplied name? With multiple class loaders the supplied name might not be the class you were intending to find.Returns all sub-classes including sub-classes of its sub-classes.Gets the key for extra information about this class.longReturns the address of the class loader which loaded this class.intReturns the id of the class loader which loaded this class.Returns field descriptors for all member variables of instances of this class.longReturns the heap size of one instance of this class.getName()Returns the fully qualified class name of this class.intReturns the number of instances of this class present in the heap dump.int[]Ids of all instances of this class (an empty array if there are no instances of the class)Get list of snapshot objects referenced from this snapshot object with the name of the field over which it was referenced.Gets the outbound references from this object, as addresses.longgetRetainedHeapSizeOfObjects(boolean calculateIfNotAvailable, boolean approximation, IProgressListener listener) Returns the retained size of all objects of this instance including the class instance.Returns the static fields and it values.Returns the direct sub-classes.Returns the super class.longGets the address of the superclass.intReturns the id of the super class.Get technical name of this object which is something like class@address.longThe size of all the instances of this class.longGet used heap size of just this object.booleanDoes the class have a super class?booleanTest if this class an array type.voidremoveInstance(long heapSizePerInstance) Remove an instance of this class.voidremoveSubClass(ClassImpl clazz) Remove a subclass of this class.voidsetCacheEntry(Serializable cacheEntry) Sets the key for extra information about this class.voidsetClassLoaderAddress(long address) Sets the class loader for this class.voidsetClassLoaderIndex(int classLoaderIndex) Sets the class loader index.voidsetHeapSizePerInstance(long size) Sets the size per instance for the classvoidSets the class name.voidsetSnapshot(ISnapshot dump) Set the snapshot for an object.voidsetSuperClassIndex(int superClassIndex) Sets the superclass index.voidsetUsedHeapSize(long usedHeapSize) Sets the used heap size for this particular class.Methods inherited from class org.eclipse.mat.parser.model.AbstractObjectImplequals, getClassAddress, getClassId, getClassSpecificName, getClazz, getComparatorForClassSpecificName, getComparatorForTechnicalName, getComparatorForUsedHeapSize, getDisplayName, getGCRootInfo, getObjectAddress, getObjectId, getRetainedHeapSize, getSnapshot, hashCode, resolveValue, setClassInstance, setObjectAddress, setObjectId, toStringMethods inherited from interface org.eclipse.mat.snapshot.model.IObjectgetClassSpecificName, getClazz, getDisplayName, getGCRootInfo, getObjectAddress, getObjectId, getRetainedHeapSize, getSnapshot, resolveValue
- 
Field Details- 
JAVA_LANG_CLASSShortcut for java.lang.Class- See Also:
 
 
- 
- 
Constructor Details- 
ClassImplpublic ClassImpl(long address, String name, long superAddress, long loaderAddress, Field[] staticFields, FieldDescriptor[] fields) Construct a class object based on name, address and fields.- Parameters:
- address- the address of the class object
- name- the class name, using '.' as package separator
- superAddress- the address of the superclass, or 0 if none.
- loaderAddress- the address of the class loader
- staticFields- all the static fields, with values
- fields- all the instance fields as descriptors
 
 
- 
- 
Method Details- 
getCacheEntryGets the key for extra information about this class.- Returns:
- the key
 
- 
setCacheEntrySets the key for extra information about this class.- Parameters:
- cacheEntry- the key
 
- 
setSuperClassIndexpublic void setSuperClassIndex(int superClassIndex) Sets the superclass index. May need to be changed after reindexing of a snapshot.- Parameters:
- superClassIndex- the new index
 
- 
setClassLoaderIndexpublic void setClassLoaderIndex(int classLoaderIndex) Sets the class loader index. May need to be changed after reindexing of a snapshot.- Parameters:
- classLoaderIndex- the new index
 
- 
getObjectIdsDescription copied from interface:IClassIds of all instances of this class (an empty array if there are no instances of the class)- Specified by:
- getObjectIdsin interface- IClass
- Returns:
- an array of all the object IDs of instances of this class
- Throws:
- SnapshotException- if there is a problem retrieving the data
- UnsupportedOperationException
 
- 
getRetainedHeapSizeOfObjectspublic long getRetainedHeapSizeOfObjects(boolean calculateIfNotAvailable, boolean approximation, IProgressListener listener) throws SnapshotException Description copied from interface:IClassReturns the retained size of all objects of this instance including the class instance.- Specified by:
- getRetainedHeapSizeOfObjectsin interface- IClass
- Parameters:
- calculateIfNotAvailable- whether to calculate
- approximation- whether an approximate calculation is sufficient
- listener- for reporting progress or for the user to cancel the calculation
- Returns:
- the total retained size in bytes, negative if an approximation
- Throws:
- SnapshotException- if there is a problem
 
- 
getUsedHeapSizepublic long getUsedHeapSize()Description copied from interface:IObjectGet used heap size of just this object.- Specified by:
- getUsedHeapSizein interface- IObject
- Specified by:
- getUsedHeapSizein class- AbstractObjectImpl
- Returns:
- used heap size of this object
 
- 
getReferencesDescription copied from class:AbstractObjectImplGets the outbound references from this object, as addresses.- Specified by:
- getReferencesin class- AbstractObjectImpl
- Returns:
- a list of outbound references
 
- 
getOutboundReferencesDescription copied from interface:IObjectGet list of snapshot objects referenced from this snapshot object with the name of the field over which it was referenced.- Specified by:
- getOutboundReferencesin interface- IObject
- Returns:
- list of snapshot objects referenced from this snapshot object with the name of the field over which it was referenced
 
- 
getClassLoaderAddresspublic long getClassLoaderAddress()Description copied from interface:IClassReturns the address of the class loader which loaded this class.- Specified by:
- getClassLoaderAddressin interface- IClass
- Returns:
- the address of the class loader
 
- 
setClassLoaderAddresspublic void setClassLoaderAddress(long address) Sets the class loader for this class.- Parameters:
- address- the address of the loader
 
- 
getFieldDescriptorsDescription copied from interface:IClassReturns field descriptors for all member variables of instances of this class. If the snapshot data format does not contain field data then this will be an empty list.- Specified by:
- getFieldDescriptorsin interface- IClass
- Returns:
- the field descriptors for this class
 
- 
getNumberOfObjectspublic int getNumberOfObjects()Description copied from interface:IClassReturns the number of instances of this class present in the heap dump.- Specified by:
- getNumberOfObjectsin interface- IClass
- Returns:
- the number of instances
 
- 
getHeapSizePerInstancepublic long getHeapSizePerInstance()Description copied from interface:IClassReturns the heap size of one instance of this class. Not valid if this class represents an array.- Specified by:
- getHeapSizePerInstancein interface- IClass
- Returns:
- the size of an instance of this class in bytes
- Since:
- 1.0
 
- 
setHeapSizePerInstancepublic void setHeapSizePerInstance(long size) Sets the size per instance for the class- Parameters:
- size- the size in bytes
- Since:
- 1.0
 
- 
getNameDescription copied from interface:IClassReturns the fully qualified class name of this class. The package components are separated by dots '.'. Inner classes use $ to separate the parts.
- 
setNameSets the class name.- Parameters:
- name- the class name
 
- 
getStaticFieldsDescription copied from interface:IClassReturns the static fields and it values. If the snapshot data format does not contain field data then this will be an empty list.- Specified by:
- getStaticFieldsin interface- IClass
- Returns:
- the static fields of this class
 
- 
getSuperClassAddresspublic long getSuperClassAddress()Gets the address of the superclass.- Returns:
- the superclass address
 
- 
getSuperClassIdpublic int getSuperClassId()Description copied from interface:IClassReturns the id of the super class. -1 if it has no super class, i.e. if it is java.lang.Object.- Specified by:
- getSuperClassIdin interface- IClass
- Returns:
- the super class ID
 
- 
getSuperClassDescription copied from interface:IClassReturns the super class.- Specified by:
- getSuperClassin interface- IClass
- Returns:
- the super class
 
- 
getTotalSizepublic long getTotalSize()The size of all the instances of this class.- Returns:
- the size in bytes
 
- 
hasSuperClasspublic boolean hasSuperClass()Description copied from interface:IClassDoes the class have a super class?- Specified by:
- hasSuperClassin interface- IClass
- Returns:
- true if the class has a super class.
 
- 
compareTo- Specified by:
- compareToin interface- Comparable<ClassImpl>
 
- 
addInstancepublic void addInstance(long usedHeapSize) Note another instance to this class.- Parameters:
- usedHeapSize- the size in bytes of this instance
- Since:
- 1.0
 
- 
removeInstancepublic void removeInstance(long heapSizePerInstance) Remove an instance of this class. Reverses the effect ofaddInstance(long)- Parameters:
- heapSizePerInstance- the size in bytes of this instance
- Since:
- 1.0
 
- 
getSubclassesDescription copied from interface:IClassReturns the direct sub-classes.- Specified by:
- getSubclassesin interface- IClass
- Returns:
- a list of the immediate subclasses
 
- 
getAllSubclassesDescription copied from interface:IClassReturns all sub-classes including sub-classes of its sub-classes.- Specified by:
- getAllSubclassesin interface- IClass
- Returns:
- a list of all the subclasses
 
- 
isArrayTypepublic boolean isArrayType()Description copied from interface:IClassTest if this class an array type.- Specified by:
- isArrayTypein interface- IClass
- Returns:
- true if the class is an array class.
 
- 
getTechnicalNameDescription copied from interface:IObjectGet technical name of this object which is something like class@address.- Specified by:
- getTechnicalNamein interface- IObject
- Overrides:
- getTechnicalNamein class- AbstractObjectImpl
- Returns:
- technical name of this object which is something like class@address
 
- 
getClassLoaderIdpublic int getClassLoaderId()Description copied from interface:IClassReturns the id of the class loader which loaded this class.- Specified by:
- getClassLoaderIdin interface- IClass
- Returns:
- the object ID of the class loader
 
- 
addSubClassAdd a subclass of this class.- Parameters:
- clazz- the subclass
 
- 
removeSubClassRemove a subclass of this class. Reverses the effect ofaddSubClass(ClassImpl)- Parameters:
- clazz- the subclass
 
- 
setUsedHeapSizepublic void setUsedHeapSize(long usedHeapSize) Sets the used heap size for this particular class. Does not include instances.- Parameters:
- usedHeapSize- the size in bytes
- Since:
- 1.0
 
- 
doesExtendDescription copied from interface:IClassDoes this class extend a class of the supplied name? With multiple class loaders the supplied name might not be the class you were intending to find.- Specified by:
- doesExtendin interface- IClass
- Parameters:
- className- the candidate class name
- Returns:
- true if it does extend
- Throws:
- SnapshotException- if there is a problem retrieving the information
 
- 
setSnapshotDescription copied from class:AbstractObjectImplSet the snapshot for an object. Used once the entire snapshot has been built, or an object has been deserialized.- Overrides:
- setSnapshotin class- AbstractObjectImpl
- Parameters:
- dump- the actual current snapshot
 
 
-