class org.openjdk.jmh.profile.GCProfiler$VMSupport
minor version: 0
major version: 59
flags: flags: (0x0020) ACC_SUPER
this_class: org.openjdk.jmh.profile.GCProfiler$VMSupport
super_class: java.lang.Object
{
private static final boolean ALLOC_AVAILABLE;
descriptor: Z
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static java.lang.management.ThreadMXBean ALLOC_MX_BEAN;
descriptor: Ljava/lang/management/ThreadMXBean;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
private static java.lang.reflect.Method ALLOC_MX_BEAN_GETTER;
descriptor: Ljava/lang/reflect/Method;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
private static final boolean CHURN_AVAILABLE;
descriptor: Z
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static javax.management.NotificationListener listener;
descriptor: Ljavax/management/NotificationListener;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
private static org.openjdk.jmh.util.Multiset<java.lang.String> churn;
descriptor: Lorg/openjdk/jmh/util/Multiset;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Signature: Lorg/openjdk/jmh/util/Multiset<Ljava/lang/String;>;
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: invokestatic org.openjdk.jmh.profile.GCProfiler$VMSupport.tryInitAlloc:()Z
putstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.ALLOC_AVAILABLE:Z
1: invokestatic org.openjdk.jmh.profile.GCProfiler$VMSupport.tryInitChurn:()Z
putstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.CHURN_AVAILABLE:Z
2: return
LocalVariableTable:
Start End Slot Name Signature
void <init>();
descriptor: ()V
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/openjdk/jmh/profile/GCProfiler$VMSupport;
private static boolean tryInitAlloc();
descriptor: ()Z
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=6, locals=4, args_size=0
0: ldc "com.sun.management.ThreadMXBean"
invokestatic java.lang.Class.forName:(Ljava/lang/String;)Ljava/lang/Class;
astore 0
start local 0 1: invokestatic java.lang.management.ManagementFactory.getThreadMXBean:()Ljava/lang/management/ThreadMXBean;
astore 1
start local 1 2: aload 0
aload 1
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
ifne 8
3: ldc "java.lang.management.PlatformManagedObject"
invokestatic java.lang.Class.forName:(Ljava/lang/String;)Ljava/lang/Class;
astore 2
start local 2 4: ldc Ljava/lang/management/ManagementFactory;
ldc "getPlatformMXBean"
iconst_2
anewarray java.lang.Class
dup
iconst_0
ldc Ljava/lang/Class;
aastore
dup
iconst_1
aload 2
aastore
invokevirtual java.lang.Class.getMethod:(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
astore 3
start local 3 5: aload 3
aconst_null
iconst_1
anewarray java.lang.Object
dup
iconst_0
aload 0
aastore
invokevirtual java.lang.reflect.Method.invoke:(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.lang.management.ThreadMXBean
astore 1
6: aload 1
ifnonnull 8
7: new java.lang.UnsupportedOperationException
dup
ldc "No way to access private ThreadMXBean"
invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
athrow
end local 3 end local 2 8: StackMap locals: java.lang.Class java.lang.management.ThreadMXBean
StackMap stack:
aload 1
putstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.ALLOC_MX_BEAN:Ljava/lang/management/ThreadMXBean;
9: aload 0
ldc "getThreadAllocatedBytes"
iconst_1
anewarray java.lang.Class
dup
iconst_0
ldc [J
aastore
invokevirtual java.lang.Class.getMethod:(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
putstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.ALLOC_MX_BEAN_GETTER:Ljava/lang/reflect/Method;
10: aload 1
invokeinterface java.lang.management.ThreadMXBean.getAllThreadIds:()[J
invokestatic org.openjdk.jmh.profile.GCProfiler$VMSupport.getAllocatedBytes:([J)[J
pop
11: iconst_1
ireturn
end local 1 end local 0 12: StackMap locals:
StackMap stack: java.lang.Throwable
astore 0
start local 0 13: getstatic java.lang.System.out:Ljava/io/PrintStream;
new java.lang.StringBuilder
dup
ldc "Allocation profiling is not available: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual java.lang.Throwable.getMessage:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
end local 0 14: iconst_0
ireturn
LocalVariableTable:
Start End Slot Name Signature
1 12 0 internalIntf Ljava/lang/Class<*>;
2 12 1 bean Ljava/lang/management/ThreadMXBean;
4 8 2 pmo Ljava/lang/Class<*>;
5 8 3 m Ljava/lang/reflect/Method;
13 14 0 e Ljava/lang/Throwable;
Exception table:
from to target type
0 11 12 Class java.lang.Throwable
private static boolean tryInitChurn();
descriptor: ()Z
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=2, args_size=0
0: invokestatic java.lang.management.ManagementFactory.getGarbageCollectorMXBeans:()Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 1
goto 4
StackMap locals: top java.util.Iterator
StackMap stack:
1: aload 1
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.management.GarbageCollectorMXBean
astore 0
start local 0 2: aload 0
instanceof javax.management.NotificationEmitter
ifne 4
3: new java.lang.UnsupportedOperationException
dup
ldc "GarbageCollectorMXBean cannot notify"
invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
athrow
end local 0 4: StackMap locals:
StackMap stack:
aload 1
invokeinterface java.util.Iterator.hasNext:()Z
ifne 1
5: invokestatic org.openjdk.jmh.profile.GCProfiler$VMSupport.newListener:()Ljavax/management/NotificationListener;
pop
6: iconst_1
ireturn
7: StackMap locals:
StackMap stack: java.lang.Throwable
astore 0
start local 0 8: getstatic java.lang.System.out:Ljava/io/PrintStream;
new java.lang.StringBuilder
dup
ldc "Churn profiling is not available: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual java.lang.Throwable.getMessage:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
end local 0 9: iconst_0
ireturn
LocalVariableTable:
Start End Slot Name Signature
2 4 0 bean Ljava/lang/management/GarbageCollectorMXBean;
8 9 0 e Ljava/lang/Throwable;
Exception table:
from to target type
0 6 7 Class java.lang.Throwable
private static long[] getAllocatedBytes(long[]);
descriptor: ([J)[J
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=6, locals=2, args_size=1
start local 0 0: getstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.ALLOC_MX_BEAN_GETTER:Ljava/lang/reflect/Method;
getstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.ALLOC_MX_BEAN:Ljava/lang/management/ThreadMXBean;
iconst_1
anewarray java.lang.Object
dup
iconst_0
aload 0
aastore
invokevirtual java.lang.reflect.Method.invoke:(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
checkcast long[]
1: areturn
2: StackMap locals:
StackMap stack: java.lang.ReflectiveOperationException
astore 1
start local 1 3: new java.lang.IllegalStateException
dup
aload 1
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 threadIds [J
3 4 1 e Ljava/lang/ReflectiveOperationException;
Exception table:
from to target type
0 1 2 Class java.lang.reflect.InvocationTargetException
0 1 2 Class java.lang.IllegalAccessException
MethodParameters:
Name Flags
threadIds
private static javax.management.NotificationListener newListener();
descriptor: ()Ljavax/management/NotificationListener;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=7, locals=6, args_size=0
0: new org.openjdk.jmh.util.HashMultiset
dup
invokespecial org.openjdk.jmh.util.HashMultiset.<init>:()V
putstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.churn:Lorg/openjdk/jmh/util/Multiset;
1: ldc "com.sun.management.GarbageCollectionNotificationInfo"
invokestatic java.lang.Class.forName:(Ljava/lang/String;)Ljava/lang/Class;
astore 0
start local 0 2: aload 0
ldc "GARBAGE_COLLECTION_NOTIFICATION"
invokevirtual java.lang.Class.getField:(Ljava/lang/String;)Ljava/lang/reflect/Field;
astore 1
start local 1 3: aload 0
ldc "from"
iconst_1
anewarray java.lang.Class
dup
iconst_0
ldc Ljavax/management/openmbean/CompositeData;
aastore
invokevirtual java.lang.Class.getMethod:(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
astore 2
start local 2 4: aload 0
ldc "getGcInfo"
iconst_0
anewarray java.lang.Class
invokevirtual java.lang.Class.getMethod:(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
astore 3
start local 3 5: aload 3
invokevirtual java.lang.reflect.Method.getReturnType:()Ljava/lang/Class;
ldc "getMemoryUsageBeforeGc"
iconst_0
anewarray java.lang.Class
invokevirtual java.lang.Class.getMethod:(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
astore 4
start local 4 6: aload 3
invokevirtual java.lang.reflect.Method.getReturnType:()Ljava/lang/Class;
ldc "getMemoryUsageAfterGc"
iconst_0
anewarray java.lang.Class
invokevirtual java.lang.Class.getMethod:(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
astore 5
start local 5 7: new org.openjdk.jmh.profile.GCProfiler$VMSupport$1
dup
aload 1
aload 2
aload 3
aload 4
aload 5
invokespecial org.openjdk.jmh.profile.GCProfiler$VMSupport$1.<init>:(Ljava/lang/reflect/Field;Ljava/lang/reflect/Method;Ljava/lang/reflect/Method;Ljava/lang/reflect/Method;Ljava/lang/reflect/Method;)V
8: areturn
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 9: StackMap locals:
StackMap stack: java.lang.Throwable
astore 0
start local 0 10: new java.lang.IllegalStateException
dup
aload 0
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 0 LocalVariableTable:
Start End Slot Name Signature
2 9 0 infoKlass Ljava/lang/Class<*>;
3 9 1 notifNameField Ljava/lang/reflect/Field;
4 9 2 infoMethod Ljava/lang/reflect/Method;
5 9 3 getGcInfo Ljava/lang/reflect/Method;
6 9 4 getMemoryUsageBeforeGc Ljava/lang/reflect/Method;
7 9 5 getMemoryUsageAfterGc Ljava/lang/reflect/Method;
10 11 0 e Ljava/lang/Throwable;
Exception table:
from to target type
1 8 9 Class java.lang.Throwable
public static org.openjdk.jmh.profile.GCProfiler$HotspotAllocationSnapshot getSnapshot();
descriptor: ()Lorg/openjdk/jmh/profile/GCProfiler$HotspotAllocationSnapshot;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=4, locals=2, args_size=0
0: getstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.ALLOC_AVAILABLE:Z
ifne 1
getstatic org.openjdk.jmh.profile.GCProfiler$HotspotAllocationSnapshot.EMPTY:Lorg/openjdk/jmh/profile/GCProfiler$HotspotAllocationSnapshot;
areturn
1: StackMap locals:
StackMap stack:
getstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.ALLOC_MX_BEAN:Ljava/lang/management/ThreadMXBean;
invokeinterface java.lang.management.ThreadMXBean.getAllThreadIds:()[J
astore 0
start local 0 2: aload 0
invokestatic org.openjdk.jmh.profile.GCProfiler$VMSupport.getAllocatedBytes:([J)[J
astore 1
start local 1 3: new org.openjdk.jmh.profile.GCProfiler$HotspotAllocationSnapshot
dup
aload 0
aload 1
invokespecial org.openjdk.jmh.profile.GCProfiler$HotspotAllocationSnapshot.<init>:([J[J)V
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
2 4 0 threadIds [J
3 4 1 allocatedBytes [J
public static synchronized void startChurnProfile();
descriptor: ()V
flags: (0x0029) ACC_PUBLIC, ACC_STATIC, ACC_SYNCHRONIZED
Code:
stack=4, locals=2, args_size=0
0: getstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.CHURN_AVAILABLE:Z
ifne 1
return
1: StackMap locals:
StackMap stack:
getstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.listener:Ljavax/management/NotificationListener;
ifnull 3
2: new java.lang.IllegalStateException
dup
ldc "Churn profile already started"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals:
StackMap stack:
invokestatic org.openjdk.jmh.profile.GCProfiler$VMSupport.newListener:()Ljavax/management/NotificationListener;
putstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.listener:Ljavax/management/NotificationListener;
4: invokestatic java.lang.management.ManagementFactory.getGarbageCollectorMXBeans:()Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 1
goto 7
StackMap locals: top java.util.Iterator
StackMap stack:
5: aload 1
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.management.GarbageCollectorMXBean
astore 0
start local 0 6: aload 0
checkcast javax.management.NotificationEmitter
getstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.listener:Ljavax/management/NotificationListener;
aconst_null
aconst_null
invokeinterface javax.management.NotificationEmitter.addNotificationListener:(Ljavax/management/NotificationListener;Ljavax/management/NotificationFilter;Ljava/lang/Object;)V
end local 0 7: StackMap locals:
StackMap stack:
aload 1
invokeinterface java.util.Iterator.hasNext:()Z
ifne 5
8: goto 11
StackMap locals:
StackMap stack: java.lang.Exception
9: pop
10: new java.lang.IllegalStateException
dup
ldc "Should not be here"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
11: StackMap locals:
StackMap stack:
return
LocalVariableTable:
Start End Slot Name Signature
6 7 0 bean Ljava/lang/management/GarbageCollectorMXBean;
Exception table:
from to target type
4 8 9 Class java.lang.Exception
public static synchronized void finishChurnProfile();
descriptor: ()V
flags: (0x0029) ACC_PUBLIC, ACC_STATIC, ACC_SYNCHRONIZED
Code:
stack=3, locals=2, args_size=0
0: getstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.CHURN_AVAILABLE:Z
ifne 1
return
1: StackMap locals:
StackMap stack:
getstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.listener:Ljavax/management/NotificationListener;
ifnonnull 3
2: new java.lang.IllegalStateException
dup
ldc "Churn profile already stopped"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals:
StackMap stack:
ldc 500
invokestatic java.lang.Thread.sleep:(J)V
4: goto 6
StackMap locals:
StackMap stack: java.lang.InterruptedException
5: pop
6: StackMap locals:
StackMap stack:
invokestatic java.lang.management.ManagementFactory.getGarbageCollectorMXBeans:()Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 1
goto 11
StackMap locals: top java.util.Iterator
StackMap stack:
7: aload 1
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.management.GarbageCollectorMXBean
astore 0
start local 0 8: aload 0
checkcast javax.management.NotificationEmitter
getstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.listener:Ljavax/management/NotificationListener;
invokeinterface javax.management.NotificationEmitter.removeNotificationListener:(Ljavax/management/NotificationListener;)V
9: goto 11
StackMap locals: java.lang.management.GarbageCollectorMXBean java.util.Iterator
StackMap stack: javax.management.ListenerNotFoundException
10: pop
end local 0 11: StackMap locals: top java.util.Iterator
StackMap stack:
aload 1
invokeinterface java.util.Iterator.hasNext:()Z
ifne 7
12: aconst_null
putstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.listener:Ljavax/management/NotificationListener;
13: return
LocalVariableTable:
Start End Slot Name Signature
8 11 0 bean Ljava/lang/management/GarbageCollectorMXBean;
Exception table:
from to target type
3 4 5 Class java.lang.InterruptedException
8 9 10 Class javax.management.ListenerNotFoundException
public static synchronized org.openjdk.jmh.util.Multiset<java.lang.String> getChurn();
descriptor: ()Lorg/openjdk/jmh/util/Multiset;
flags: (0x0029) ACC_PUBLIC, ACC_STATIC, ACC_SYNCHRONIZED
Code:
stack=2, locals=0, args_size=0
0: getstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.churn:Lorg/openjdk/jmh/util/Multiset;
ifnull 1
getstatic org.openjdk.jmh.profile.GCProfiler$VMSupport.churn:Lorg/openjdk/jmh/util/Multiset;
goto 2
StackMap locals:
StackMap stack:
1: new org.openjdk.jmh.util.HashMultiset
dup
invokespecial org.openjdk.jmh.util.HashMultiset.<init>:()V
StackMap locals:
StackMap stack: org.openjdk.jmh.util.Multiset
2: areturn
LocalVariableTable:
Start End Slot Name Signature
Signature: ()Lorg/openjdk/jmh/util/Multiset<Ljava/lang/String;>;
}
SourceFile: "GCProfiler.java"
NestHost: org.openjdk.jmh.profile.GCProfiler
InnerClasses:
HotspotAllocationSnapshot = org.openjdk.jmh.profile.GCProfiler$HotspotAllocationSnapshot of org.openjdk.jmh.profile.GCProfiler
VMSupport = org.openjdk.jmh.profile.GCProfiler$VMSupport of org.openjdk.jmh.profile.GCProfiler
org.openjdk.jmh.profile.GCProfiler$VMSupport$1