- 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 TypeMethodDescriptionboolean
containsKey
(String key) Returnstrue
if and only if thisCompositeData
instance contains an item whose name iskey
.boolean
containsValue
(Object value) Returnstrue
if and only if thisCompositeData
instance contains an item whose value isvalue
.boolean
Indicates whether some other object is "equal to" this one.static GcInfo
from
(CompositeData cd) Returns aGcInfo
object 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
.long
The number of bytes allocated in the memory pools affected by the associated collector during the time interval returned bygetTimeFromEndOfPreviousToStartNanos
.long
The number of bytes allocated in the memory pools affected by the associated collector during the time interval returned bygetDurationNanos
.double
The approximate object allocation rate in megabytes per second in the memory pools affected by the associated collector during the time interval returned bygetTimeFromEndOfPreviousToStartNanos
.double
The 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.AList
ofConcurrentInfo
for the concurrent phases of this collection.long
If objects were copied between the memory pools affected by this collection, their aggregate size in bytes.long
Returns the elapsed time of this GC in milliseconds.long
The approximate elapsed wall clock time in nanoseconds between the start and end of this collection.long
Returns the end time of this GC in milliseconds since the Java virtual machine was started.long
The approximate end time of this collection in nanoseconds since Java virtual machine launch.long
The aggregate size, in bytes, of all objects collected by the associated collector during this collection.The reason for this collection.long
The aggregate size, in bytes, of all unreachable objects discovered by the associated collector during this collection.long
getId()
Returns the identifier of this garbage collection, which is the number of collections that this collector has done.long
At the end of this collection, the approximate number of bytes occupied by live objects in the memory pools affected by the associated collector.long
At 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.double
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.long
The approximate end time of the last previous collection in nanoseconds since Java virtual machine launch.long
Returns the start time of this GC in milliseconds since the Java virtual machine was started.long
The approximate start time of this collection in nanoseconds since Java virtual machine launch.long
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.long
The version of thisGcInfo
that determines the attributes it supports.int
hashCode()
Returns a hash code value for the object.boolean
isValid()
Whether the data returned by thisGcInfo
object has passed all validity tests.Return theCompositeData
representation 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 thisCompositeData
instance.
-
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 aMap
of the name of a memory pool to the memory usage of the corresponding memory pool before GC starts.- Returns:
- a
Map
of 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 aMap
of the name of a memory pool to the memory usage of the corresponding memory pool when GC finishes.- Returns:
- a
Map
of memory pool names to the memory usage of a memory pool when GC finishes.
-
isValid
public boolean isValid()Whether the data returned by thisGcInfo
object has passed all validity tests.- Returns:
true
if the data in thisGcInfo
is 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
String
representing 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
-1
if 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
-1
if 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 afterMemoryUsage
occupancy 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
AList
ofConcurrentInfo
for the concurrent phases of this collection.- Returns:
- a List of
ConcurrentInfo
for the concurrent phases of this collection.
-
getVersion
public long getVersion()The version of thisGcInfo
that determines the attributes it supports.- Returns:
- a
Long
representing the GcInfo version.
-
from
Returns aGcInfo
object represented by the givenCompositeData
. The givenCompositeData
must contain all the following attributes:Attribute Name Type index java.lang.Long
startTime java.lang.Long
endTime java.lang.Long
memoryUsageBeforeGc javax.management.openmbean.TabularData
memoryUsageAfterGc javax.management.openmbean.TabularData
- Returns:
- a
GcInfo
object represented bycd
ifcd
is notnull
;null
otherwise. - Throws:
IllegalArgumentException
- ifcd
does not represent aGcInfo
object with the attributes described above.
-
containsKey
Description copied from interface:CompositeData
Returnstrue
if and only if thisCompositeData
instance contains an item whose name iskey
. Ifkey
is a null or empty String, this method simply returns false.- Specified by:
containsKey
in interfaceCompositeData
- Parameters:
key
- the key to be tested.- Returns:
- true if this
CompositeData
contains the key.
-
containsValue
Description copied from interface:CompositeData
Returnstrue
if and only if thisCompositeData
instance contains an item whose value isvalue
.- Specified by:
containsValue
in interfaceCompositeData
- Parameters:
value
- the value to be tested.- Returns:
- true if this
CompositeData
contains the value.
-
equals
Description copied from class:Object
Indicates whether some other object is "equal to" this one.The
equals
method 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
x
andy
,x.equals(y)
should returntrue
if and only ify.equals(x)
returnstrue
. - It is transitive: for any non-null reference values
x
,y
, andz
, ifx.equals(y)
returnstrue
andy.equals(z)
returnstrue
, thenx.equals(z)
should returntrue
. - It is consistent: for any non-null reference values
x
andy
, multiple invocations ofx.equals(y)
consistently returntrue
or consistently returnfalse
, provided no information used inequals
comparisons 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:
equals
in interfaceCompositeData
- Overrides:
equals
in classObject
- Parameters:
obj
- the reference object with which to compare.- Returns:
true
if this object is the same as the obj argument;false
otherwise.- See Also:
- It is reflexive: for any non-null reference value
-
get
Description copied from interface:CompositeData
Returns the value of the item whose name iskey
.- Specified by:
get
in interfaceCompositeData
- Parameters:
key
- the name of the item.- Returns:
- the value associated with this key.
-
getAll
Description copied from interface:CompositeData
Returns an array of the values of the items whose names are specified bykeys
, in the same order askeys
.- Specified by:
getAll
in interfaceCompositeData
- Parameters:
keys
- the names of the items.- Returns:
- the values corresponding to the keys.
-
getCompositeType
Description copied from interface:CompositeData
Returns the composite type of this composite data instance.- Specified by:
getCompositeType
in interfaceCompositeData
- Returns:
- the type of this CompositeData.
-
hashCode
public int hashCode()Description copied from class:Object
Returns 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
hashCode
is:- Whenever it is invoked on the same object more than once during
an execution of a Java application, the
hashCode
method must consistently return the same integer, provided no information used inequals
comparisons 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
equals
method, then calling thehashCode
method 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
equals
method, then calling thehashCode
method 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:
hashCode
in interfaceCompositeData
- Overrides:
hashCode
in 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:Object
Returns a string representation of the object.- Specified by:
toString
in interfaceCompositeData
- Overrides:
toString
in classObject
- Returns:
- a string representation of the object.
-
values
Description copied from interface:CompositeData
Returns an unmodifiable Collection view of the item values contained in thisCompositeData
instance. The returned collection's iterator will return the values in the ascending lexicographic order of the corresponding item names.- Specified by:
values
in interfaceCompositeData
- Returns:
- the values.
-
toCompositeData
Return theCompositeData
representation of thisGcInfo
, including any GC-specific attributes. The returned value will have at least all the attributes described in thefrom
method, plus optionally other attributes.- Specified by:
toCompositeData
in interfaceCompositeDataView
- Parameters:
ct
- theCompositeType
that the caller expects. This parameter is ignored and can be null.- Returns:
- the
CompositeData
representation.
-