- All Implemented Interfaces:
CompositeData,CompositeDataView
- Start time
- End time
- Duration
- Memory usage before the collection starts
- Memory usage after the collection ends
GcInfo is a CompositeData
The GC-specific attributes can be obtained via the CompositeData
interface. This is a historical relic, and other classes should
not copy this pattern. Use CompositeDataView instead.
MXBean Mapping
GcInfo is mapped to a CompositeData
with attributes as specified in the from method.- Since:
- 1.5
-
Method Summary
Modifier and TypeMethodDescriptionbooleancontainsKey(String key) Returnstrueif and only if thisCompositeDatainstance contains an item whose name iskey.booleancontainsValue(Object value) Returnstrueif and only if thisCompositeDatainstance contains an item whose value isvalue.booleanIndicates whether some other object is "equal to" this one.static GcInfofrom(CompositeData cd) Returns aGcInfoobject represented by the givenCompositeData.Returns the value of the item whose name iskey.Object[]Returns an array of the values of the items whose names are specified bykeys, in the same order askeys.longThe number of bytes allocated in the memory pools affected by the associated collector during the time interval returned bygetTimeFromEndOfPreviousToStartNanos.longThe number of bytes allocated in the memory pools affected by the associated collector during the time interval returned bygetDurationNanos.doubleThe approximate object allocation rate in megabytes per second in the memory pools affected by the associated collector during the time interval returned bygetTimeFromEndOfPreviousToStartNanos.doubleThe approximate object allocation rate in megabytes per second in the memory pools affected by the associated collector during the time interval returned bygetDurationNanos.Returns the composite type of this composite data instance.AListofConcurrentInfofor the concurrent phases of this collection.longIf objects were copied between the memory pools affected by this collection, their aggregate size in bytes.longReturns the elapsed time of this GC in milliseconds.longThe approximate elapsed wall clock time in nanoseconds between the start and end of this collection.longReturns the end time of this GC in milliseconds since the Java virtual machine was started.longThe approximate end time of this collection in nanoseconds since Java virtual machine launch.longThe aggregate size, in bytes, of all objects collected by the associated collector during this collection.The reason for this collection.longThe aggregate size, in bytes, of all unreachable objects discovered by the associated collector during this collection.longgetId()Returns the identifier of this garbage collection, which is the number of collections that this collector has done.longAt the end of this collection, the approximate number of bytes occupied by live objects in the memory pools affected by the associated collector.longAt the start of this collection, the approximate number of bytes occupied by live objects in the memory pools affected by the associated collector.Returns the memory usage of all memory pools at the end of this GC.Returns the memory usage of all memory pools at the beginning of this GC.doubleThe percentage of time that the associated collector ran over the time interval between the end of the last previous collection run by it and the end of this collection.longThe approximate end time of the last previous collection in nanoseconds since Java virtual machine launch.longReturns the start time of this GC in milliseconds since the Java virtual machine was started.longThe approximate start time of this collection in nanoseconds since Java virtual machine launch.longThe approximate amount of time in nanoseconds from the end of the last previous collection run by the associated collector to the start of this collection.longThe version of thisGcInfothat determines the attributes it supports.inthashCode()Returns a hash code value for the object.booleanisValid()Whether the data returned by thisGcInfoobject has passed all validity tests.Return theCompositeDatarepresentation of thisGcInfo, including any GC-specific attributes.toString()Returns a string representation of the object.Collection<?>values()Returns an unmodifiable Collection view of the item values contained in thisCompositeDatainstance.
-
Method Details
-
getId
public long getId()Returns the identifier of this garbage collection, which is the number of collections that this collector has done.- Returns:
- the identifier of this garbage collection, which is the number of collections that this collector has done.
-
getStartTime
public long getStartTime()Returns the start time of this GC in milliseconds since the Java virtual machine was started.- Returns:
- the start time of this GC.
-
getEndTime
public long getEndTime()Returns the end time of this GC in milliseconds since the Java virtual machine was started.- Returns:
- the end time of this GC.
-
getDuration
public long getDuration()Returns the elapsed time of this GC in milliseconds.- Returns:
- the elapsed time of this GC in milliseconds.
-
getMemoryUsageBeforeGc
Returns the memory usage of all memory pools at the beginning of this GC. This method returns aMapof the name of a memory pool to the memory usage of the corresponding memory pool before GC starts.- Returns:
- a
Mapof memory pool names to the memory usage of a memory pool before GC starts.
-
getMemoryUsageAfterGc
Returns the memory usage of all memory pools at the end of this GC. This method returns aMapof the name of a memory pool to the memory usage of the corresponding memory pool when GC finishes.- Returns:
- a
Mapof memory pool names to the memory usage of a memory pool when GC finishes.
-
isValid
public boolean isValid()Whether the data returned by thisGcInfoobject has passed all validity tests.- Returns:
trueif the data in thisGcInfois valid; otherwise,false.
-
getGarbageCollectionCause
The reason for this collection. The most common one is when the Java virtual machine detects that all available Java heap space has been occupied, or that the Java virtual machine estimates that all available space will soon be occupied. A Java virtual machine might use "Max" as the string to identify this cause for starting a collection, or possibly "Alo" for an object allocation failure. The reason is unique across all collectors supported by the Java virtual machine.- Returns:
- a
Stringrepresenting the reason for this collection.
-
getLiveInPoolsBeforeGc
public long getLiveInPoolsBeforeGc()At the start of this collection, the approximate number of bytes occupied by live objects in the memory pools affected by the associated collector. If this operation is not supported, this method returns-1.Note that "the memory pools affected by the associated collector" may not be the same as "the memory pools affected by this collection".
- Returns:
- the approximate number of bytes occupied by live objects in the
memory pools affected by the associated collector at the start
of this collection; or
-1if this operation is not supported.
-
getLiveInPoolsAfterGc
public long getLiveInPoolsAfterGc()At the end of this collection, the approximate number of bytes occupied by live objects in the memory pools affected by the associated collector. If this operation is not supported, this method returns-1.Note that "the memory pools affected by the associated collector" may not be the same as "the memory pools affected by this collection".
- Returns:
- the approximate number of bytes occupied by live objects in the
memory pools affected by the associated collector at the end of
this collection; or
-1if this operation is not supported.
-
getGarbageFound
public long getGarbageFound()The aggregate size, in bytes, of all unreachable objects discovered by the associated collector during this collection.- Returns:
- the aggregate size, in bytes, of all unreachable objects discovered by the associated collector during this collection.
-
getGarbageCollected
public long getGarbageCollected()The aggregate size, in bytes, of all objects collected by the associated collector during this collection.- Returns:
- the aggregate size, in bytes, of all objects collected by the associated collector during this collection.
-
getCopiedBetweenPools
public long getCopiedBetweenPools()If objects were copied between the memory pools affected by this collection, their aggregate size in bytes. If this is a young collection in a two-generation system, this value is the total size of objects promoted to the old generation. This value is not the same as the difference in before and afterMemoryUsageoccupancy because allocation in the targetMemoryPool(s) may have been done by other than the GC threads that ran this collection.- Returns:
- the aggregate size in bytes of objects copied between the memory pools affected by this collection.
-
getStartTimeNanos
public long getStartTimeNanos()The approximate start time of this collection in nanoseconds since Java virtual machine launch.- Returns:
- the start time of this collection.
-
getEndTimeNanos
public long getEndTimeNanos()The approximate end time of this collection in nanoseconds since Java virtual machine launch.- Returns:
- the end time of this collection.
-
getDurationNanos
public long getDurationNanos()The approximate elapsed wall clock time in nanoseconds between the start and end of this collection. The returned value is equal togetEndTimeNanos() -getStartTimeNanos().- Returns:
- the elapsed time of this collection.
-
getTimeFromEndOfPreviousToStartNanos
public long getTimeFromEndOfPreviousToStartNanos()The approximate amount of time in nanoseconds from the end of the last previous collection run by the associated collector to the start of this collection. The time interval represents the amount of time the collector did not run.- Returns:
- the amount of time from the end of the last previous collection run by the associated collector to the start of this collection.
-
getPercentageOfTimeCollectorWasRunning
public double getPercentageOfTimeCollectorWasRunning()The percentage of time that the associated collector ran over the time interval between the end of the last previous collection run by it and the end of this collection. The percentage is calculated by: (getDurationSeconds() / ( (double)getTimeFromEndOfPreviousToStartNanos() +getDurationSeconds() ) ) * 100.- Returns:
- the percentage of time the associated collector ran between the end of its last previous collection and the end of this collection.
-
getAllocRateDuringCollection
public double getAllocRateDuringCollection()The approximate object allocation rate in megabytes per second in the memory pools affected by the associated collector during the time interval returned bygetDurationNanos.Note that "the memory pools affected by the associated collector" may not be the same as "the memory pools affected by this collection".
- Returns:
- the object allocation rate in megabytes per second during the time interval between the start and end of this collection.
-
getAllocRateBetweenEndOfPreviousAndStart
public double getAllocRateBetweenEndOfPreviousAndStart()The approximate object allocation rate in megabytes per second in the memory pools affected by the associated collector during the time interval returned bygetTimeFromEndOfPreviousToStartNanos.Note that "the memory pools affected by the associated collector" may not be the same as "the memory pools affected by this collection".
- Returns:
- the object allocation rate in megabytes per second during the time interval between the end of the last previous collection and the start of this collection.
-
getPreviousEndTimeNanos
public long getPreviousEndTimeNanos()The approximate end time of the last previous collection in nanoseconds since Java virtual machine launch.- Returns:
- the end time of the last previous collection.
-
getAllocatedDuringCollection
public long getAllocatedDuringCollection()The number of bytes allocated in the memory pools affected by the associated collector during the time interval returned bygetDurationNanos.Note that "the memory pools affected by the associated collector" may not be the same as "the memory pools affected by this collection".
- Returns:
- the object allocated bytes during the time interval between the start and end of this collection.
-
getAllocatedBetweenEndOfPreviousAndStart
public long getAllocatedBetweenEndOfPreviousAndStart()The number of bytes allocated in the memory pools affected by the associated collector during the time interval returned bygetTimeFromEndOfPreviousToStartNanos.Note that "the memory pools affected by the associated collector" may not be the same as "the memory pools affected by this collection".
- Returns:
- the object allocated bytes during the time interval between the end of the last previous collection and the start of this collection.
-
getPauseInfo
- Returns:
- a List of PauseInfo for the pauses during this collection.
-
getConcurrentInfo
AListofConcurrentInfofor the concurrent phases of this collection.- Returns:
- a List of
ConcurrentInfofor the concurrent phases of this collection.
-
getVersion
public long getVersion()The version of thisGcInfothat determines the attributes it supports.- Returns:
- a
Longrepresenting the GcInfo version.
-
from
Returns aGcInfoobject represented by the givenCompositeData. The givenCompositeDatamust contain all the following attributes:Attribute Name Type index java.lang.LongstartTime java.lang.LongendTime java.lang.LongmemoryUsageBeforeGc javax.management.openmbean.TabularDatamemoryUsageAfterGc javax.management.openmbean.TabularData- Returns:
- a
GcInfoobject represented bycdifcdis notnull;nullotherwise. - Throws:
IllegalArgumentException- ifcddoes not represent aGcInfoobject with the attributes described above.
-
containsKey
Description copied from interface:CompositeDataReturnstrueif and only if thisCompositeDatainstance contains an item whose name iskey. Ifkeyis a null or empty String, this method simply returns false.- Specified by:
containsKeyin interfaceCompositeData- Parameters:
key- the key to be tested.- Returns:
- true if this
CompositeDatacontains the key.
-
containsValue
Description copied from interface:CompositeDataReturnstrueif and only if thisCompositeDatainstance contains an item whose value isvalue.- Specified by:
containsValuein interfaceCompositeData- Parameters:
value- the value to be tested.- Returns:
- true if this
CompositeDatacontains the value.
-
equals
Description copied from class:ObjectIndicates whether some other object is "equal to" this one.The
equalsmethod implements an equivalence relation on non-null object references:- It is reflexive: for any non-null reference value
x,x.equals(x)should returntrue. - It is symmetric: for any non-null reference values
xandy,x.equals(y)should returntrueif and only ify.equals(x)returnstrue. - It is transitive: for any non-null reference values
x,y, andz, ifx.equals(y)returnstrueandy.equals(z)returnstrue, thenx.equals(z)should returntrue. - It is consistent: for any non-null reference values
xandy, multiple invocations ofx.equals(y)consistently returntrueor consistently returnfalse, provided no information used inequalscomparisons on the objects is modified. - For any non-null reference value
x,x.equals(null)should returnfalse.
An equivalence relation partitions the elements it operates on into equivalence classes; all the members of an equivalence class are equal to each other. Members of an equivalence class are substitutable for each other, at least for some purposes.
- Specified by:
equalsin interfaceCompositeData- Overrides:
equalsin classObject- Parameters:
obj- the reference object with which to compare.- Returns:
trueif this object is the same as the obj argument;falseotherwise.- See Also:
- It is reflexive: for any non-null reference value
-
get
Description copied from interface:CompositeDataReturns the value of the item whose name iskey.- Specified by:
getin interfaceCompositeData- Parameters:
key- the name of the item.- Returns:
- the value associated with this key.
-
getAll
Description copied from interface:CompositeDataReturns an array of the values of the items whose names are specified bykeys, in the same order askeys.- Specified by:
getAllin interfaceCompositeData- Parameters:
keys- the names of the items.- Returns:
- the values corresponding to the keys.
-
getCompositeType
Description copied from interface:CompositeDataReturns the composite type of this composite data instance.- Specified by:
getCompositeTypein interfaceCompositeData- Returns:
- the type of this CompositeData.
-
hashCode
public int hashCode()Description copied from class:ObjectReturns a hash code value for the object. This method is supported for the benefit of hash tables such as those provided byHashMap.The general contract of
hashCodeis:- Whenever it is invoked on the same object more than once during
an execution of a Java application, the
hashCodemethod must consistently return the same integer, provided no information used inequalscomparisons on the object is modified. This integer need not remain consistent from one execution of an application to another execution of the same application. - If two objects are equal according to the
equalsmethod, then calling thehashCodemethod on each of the two objects must produce the same integer result. - It is not required that if two objects are unequal
according to the
equalsmethod, then calling thehashCodemethod on each of the two objects must produce distinct integer results. However, the programmer should be aware that producing distinct integer results for unequal objects may improve the performance of hash tables.
- Specified by:
hashCodein interfaceCompositeData- Overrides:
hashCodein classObject- Returns:
- a hash code value for this object.
- See Also:
- Whenever it is invoked on the same object more than once during
an execution of a Java application, the
-
toString
Description copied from class:ObjectReturns a string representation of the object.- Specified by:
toStringin interfaceCompositeData- Overrides:
toStringin classObject- Returns:
- a string representation of the object.
-
values
Description copied from interface:CompositeDataReturns an unmodifiable Collection view of the item values contained in thisCompositeDatainstance. The returned collection's iterator will return the values in the ascending lexicographic order of the corresponding item names.- Specified by:
valuesin interfaceCompositeData- Returns:
- the values.
-
toCompositeData
Return theCompositeDatarepresentation of thisGcInfo, including any GC-specific attributes. The returned value will have at least all the attributes described in thefrommethod, plus optionally other attributes.- Specified by:
toCompositeDatain interfaceCompositeDataView- Parameters:
ct- theCompositeTypethat the caller expects. This parameter is ignored and can be null.- Returns:
- the
CompositeDatarepresentation.
-