Kieker 1.11

kieker.common.record.jvm
Class MemoryRecord

java.lang.Object
  extended by kieker.common.record.AbstractMonitoringRecord
      extended by kieker.common.record.jvm.AbstractJVMRecord
          extended by kieker.common.record.jvm.MemoryRecord
All Implemented Interfaces:
java.io.Serializable, java.lang.Comparable<IMonitoringRecord>, IMonitoringRecord, IMonitoringRecord.BinaryFactory, IMonitoringRecord.Factory

public class MemoryRecord
extends AbstractJVMRecord

Since:
1.10
Author:
Nils Christian Ehmke
See Also:
Serialized Form

Nested Class Summary
 
Nested classes/interfaces inherited from interface kieker.common.record.IMonitoringRecord
IMonitoringRecord.BinaryFactory, IMonitoringRecord.Factory
 
Field Summary
static int SIZE
          Descriptive definition of the serialization size of the record.
static java.lang.Class<?>[] TYPES
           
 
Fields inherited from class kieker.common.record.jvm.AbstractJVMRecord
HOSTNAME, VM_NAME
 
Fields inherited from class kieker.common.record.AbstractMonitoringRecord
TYPE_SIZE_BOOLEAN, TYPE_SIZE_BYTE, TYPE_SIZE_CHARACTER, TYPE_SIZE_DOUBLE, TYPE_SIZE_FLOAT, TYPE_SIZE_INT, TYPE_SIZE_LONG, TYPE_SIZE_SHORT, TYPE_SIZE_STRING
 
Constructor Summary
  MemoryRecord(java.nio.ByteBuffer buffer, IRegistry<java.lang.String> stringRegistry)
          This constructor converts the given array into a record.
  MemoryRecord(long timestamp, java.lang.String hostname, java.lang.String vmName, long heapMaxBytes, long heapUsedBytes, long heapCommittedBytes, long heapInitBytes, long nonHeapMaxBytes, long nonHeapUsedBytes, long nonHeapCommittedBytes, long nonHeapInitBytes, int objectPendingFinalizationCount)
          Creates a new instance of this class using the given parameters.
  MemoryRecord(java.lang.Object[] values)
          This constructor converts the given array into a record.
protected MemoryRecord(java.lang.Object[] values, java.lang.Class<?>[] valueTypes)
          This constructor uses the given array to initialize the fields of this record.
 
Method Summary
 long getHeapCommittedBytes()
           
 long getHeapInitBytes()
           
 long getHeapMaxBytes()
           
 long getHeapUsedBytes()
           
 long getNonHeapCommittedBytes()
           
 long getNonHeapInitBytes()
           
 long getNonHeapMaxBytes()
           
 long getNonHeapUsedBytes()
           
 int getObjectPendingFinalizationCount()
           
 int getSize()
          This method should deliver the size of a binary representation of this record.
 java.lang.Class<?>[] getValueTypes()
          This method should deliver an array with the classes of the single values for the record.
 void initFromArray(java.lang.Object[] values)
          Deprecated. This record uses the IMonitoringRecord.Factory mechanism. Hence, this method is not implemented.
 void initFromBytes(java.nio.ByteBuffer buffer, IRegistry<java.lang.String> stringRegistry)
          Deprecated. This record uses the IMonitoringRecord.BinaryFactory mechanism. Hence, this method is not implemented.
 java.lang.Object[] toArray()
          This method should deliver an array containing the content of the record.
 void writeBytes(java.nio.ByteBuffer buffer, IRegistry<java.lang.String> stringRegistry)
          This method should deliver an byte array containing the content of the record.
 
Methods inherited from class kieker.common.record.jvm.AbstractJVMRecord
getHostname, getTimestamp, getVmName
 
Methods inherited from class kieker.common.record.AbstractMonitoringRecord
checkArray, classForName, compareTo, createFromArray, createFromArray, createFromByteBuffer, createFromByteBuffer, createFromStringArray, equals, fromStringArrayToTypedArray, getLoggingTimestamp, hashCode, registerStrings, setLoggingTimestamp, toString, typesForClass
 
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
 

Field Detail

SIZE

public static final int SIZE
Descriptive definition of the serialization size of the record.

See Also:
Constant Field Values

TYPES

public static final java.lang.Class<?>[] TYPES
Constructor Detail

MemoryRecord

public MemoryRecord(long timestamp,
                    java.lang.String hostname,
                    java.lang.String vmName,
                    long heapMaxBytes,
                    long heapUsedBytes,
                    long heapCommittedBytes,
                    long heapInitBytes,
                    long nonHeapMaxBytes,
                    long nonHeapUsedBytes,
                    long nonHeapCommittedBytes,
                    long nonHeapInitBytes,
                    int objectPendingFinalizationCount)
Creates a new instance of this class using the given parameters.

Parameters:
timestamp - timestamp
hostname - hostname
vmName - vmName
heapMaxBytes - heapMaxBytes
heapUsedBytes - heapUsedBytes
heapCommittedBytes - heapCommittedBytes
heapInitBytes - heapInitBytes
nonHeapMaxBytes - nonHeapMaxBytes
nonHeapUsedBytes - nonHeapUsedBytes
nonHeapCommittedBytes - nonHeapCommittedBytes
nonHeapInitBytes - nonHeapInitBytes
objectPendingFinalizationCount - objectPendingFinalizationCount

MemoryRecord

public MemoryRecord(java.lang.Object[] values)
This constructor converts the given array into a record. It is recommended to use the array which is the result of a call to toArray().

Parameters:
values - The values for the record.

MemoryRecord

protected MemoryRecord(java.lang.Object[] values,
                       java.lang.Class<?>[] valueTypes)
This constructor uses the given array to initialize the fields of this record.

Parameters:
values - The values for the record.
valueTypes - The types of the elements in the first array.

MemoryRecord

public MemoryRecord(java.nio.ByteBuffer buffer,
                    IRegistry<java.lang.String> stringRegistry)
             throws java.nio.BufferUnderflowException
This constructor converts the given array into a record.

Parameters:
buffer - The bytes for the record.
Throws:
java.nio.BufferUnderflowException - if buffer not sufficient
Method Detail

toArray

public java.lang.Object[] toArray()
This method should deliver an array containing the content of the record. It should be possible to convert this array later into a record again.

Returns:
An array with the values of the record.

writeBytes

public void writeBytes(java.nio.ByteBuffer buffer,
                       IRegistry<java.lang.String> stringRegistry)
                throws java.nio.BufferOverflowException
This method should deliver an byte array containing the content of the record. It should be possible to convert this array later into a record again.

Parameters:
buffer - The used ByteBuffer with sufficient capacity
stringRegistry - Usually the associated MonitoringController
Throws:
java.nio.BufferOverflowException - if buffer not sufficient

getValueTypes

public java.lang.Class<?>[] getValueTypes()
This method should deliver an array with the classes of the single values for the record.

Returns:
The types of the values. This returned array should be treated readonly.
See Also:
IMonitoringRecord.toArray()

getSize

public int getSize()
This method should deliver the size of a binary representation of this record.

Returns:
The size.

initFromArray

@Deprecated
public void initFromArray(java.lang.Object[] values)
Deprecated. This record uses the IMonitoringRecord.Factory mechanism. Hence, this method is not implemented.

This method should initialize the record based on the given values. The array should be one of those resulting from a call to IMonitoringRecord.toArray().

Specified by:
initFromArray in interface IMonitoringRecord
Overrides:
initFromArray in class AbstractJVMRecord
Parameters:
values - The values for the record.

initFromBytes

@Deprecated
public void initFromBytes(java.nio.ByteBuffer buffer,
                                     IRegistry<java.lang.String> stringRegistry)
                   throws java.nio.BufferUnderflowException
Deprecated. This record uses the IMonitoringRecord.BinaryFactory mechanism. Hence, this method is not implemented.

This method should initialize the record based on the given values. The array should be one of those resulting from a call to IMonitoringRecord.writeBytes(ByteBuffer, IRegistry).

Specified by:
initFromBytes in interface IMonitoringRecord
Overrides:
initFromBytes in class AbstractJVMRecord
Parameters:
buffer - The bytes for the record.
stringRegistry - The Registry storing the strings.
Throws:
java.nio.BufferUnderflowException - if buffer not sufficient

getHeapMaxBytes

public final long getHeapMaxBytes()

getHeapUsedBytes

public final long getHeapUsedBytes()

getHeapCommittedBytes

public final long getHeapCommittedBytes()

getHeapInitBytes

public final long getHeapInitBytes()

getNonHeapMaxBytes

public final long getNonHeapMaxBytes()

getNonHeapUsedBytes

public final long getNonHeapUsedBytes()

getNonHeapCommittedBytes

public final long getNonHeapCommittedBytes()

getNonHeapInitBytes

public final long getNonHeapInitBytes()

getObjectPendingFinalizationCount

public final int getObjectPendingFinalizationCount()

Kieker 1.11

Copyright 2015 Kieker Project, http://kieker-monitoring.net