public class org.openjdk.jmh.profile.StackProfiler$SamplingTask implements java.lang.Runnable
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.openjdk.jmh.profile.StackProfiler$SamplingTask
super_class: java.lang.Object
{
private final java.lang.Thread thread;
descriptor: Ljava/lang/Thread;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.Map<java.lang.Thread$State, org.openjdk.jmh.util.Multiset<org.openjdk.jmh.profile.StackProfiler$StackRecord>> stacks;
descriptor: Ljava/util/Map;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/Map<Ljava/lang/Thread$State;Lorg/openjdk/jmh/util/Multiset<Lorg/openjdk/jmh/profile/StackProfiler$StackRecord;>;>;
final org.openjdk.jmh.profile.StackProfiler this$0;
descriptor: Lorg/openjdk/jmh/profile/StackProfiler;
flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC
public void <init>(org.openjdk.jmh.profile.StackProfiler);
descriptor: (Lorg/openjdk/jmh/profile/StackProfiler;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=6, args_size=2
start local 0 0: aload 0
aload 1
putfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.this$0:Lorg/openjdk/jmh/profile/StackProfiler;
aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new java.util.EnumMap
dup
ldc Ljava/lang/Thread$State;
invokespecial java.util.EnumMap.<init>:(Ljava/lang/Class;)V
putfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.stacks:Ljava/util/Map;
2: invokestatic java.lang.Thread$State.values:()[Ljava/lang/Thread$State;
dup
astore 5
arraylength
istore 4
iconst_0
istore 3
goto 6
StackMap locals: org.openjdk.jmh.profile.StackProfiler$SamplingTask org.openjdk.jmh.profile.StackProfiler top int int java.lang.Thread$State[]
StackMap stack:
3: aload 5
iload 3
aaload
astore 2
start local 2 4: aload 0
getfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.stacks:Ljava/util/Map;
aload 2
new org.openjdk.jmh.util.HashMultiset
dup
invokespecial org.openjdk.jmh.util.HashMultiset.<init>:()V
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
end local 2 5: iinc 3 1
StackMap locals:
StackMap stack:
6: iload 3
iload 4
if_icmplt 3
7: aload 0
new java.lang.Thread
dup
aload 0
invokespecial java.lang.Thread.<init>:(Ljava/lang/Runnable;)V
putfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.thread:Ljava/lang/Thread;
8: aload 0
getfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.thread:Ljava/lang/Thread;
ldc "Sampling Thread"
invokevirtual java.lang.Thread.setName:(Ljava/lang/String;)V
9: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/openjdk/jmh/profile/StackProfiler$SamplingTask;
4 5 2 s Ljava/lang/Thread$State;
MethodParameters:
Name Flags
this$0 final
public void run();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=13, args_size=1
start local 0 0: goto 35
1: StackMap locals:
StackMap stack:
invokestatic java.lang.management.ManagementFactory.getThreadMXBean:()Ljava/lang/management/ThreadMXBean;
iconst_0
iconst_0
invokeinterface java.lang.management.ThreadMXBean.dumpAllThreads:(ZZ)[Ljava/lang/management/ThreadInfo;
astore 1
start local 1 2: aload 1
dup
astore 5
arraylength
istore 4
iconst_0
istore 3
goto 30
StackMap locals: org.openjdk.jmh.profile.StackProfiler$SamplingTask java.lang.management.ThreadInfo[] top int int java.lang.management.ThreadInfo[]
StackMap stack:
3: aload 5
iload 3
aaload
astore 2
start local 2 4: getstatic org.openjdk.jmh.profile.StackProfiler.IGNORED_THREADS:[Ljava/lang/String;
dup
astore 9
arraylength
istore 8
iconst_0
istore 7
goto 9
StackMap locals: org.openjdk.jmh.profile.StackProfiler$SamplingTask java.lang.management.ThreadInfo[] java.lang.management.ThreadInfo int int java.lang.management.ThreadInfo[] top int int java.lang.String[]
StackMap stack:
5: aload 9
iload 7
aaload
astore 6
start local 6 6: aload 2
invokevirtual java.lang.management.ThreadInfo.getThreadName:()Ljava/lang/String;
aload 6
invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
ifeq 8
7: goto 29
end local 6 8: StackMap locals:
StackMap stack:
iinc 7 1
StackMap locals:
StackMap stack:
9: iload 7
iload 8
if_icmplt 5
10: aload 2
invokevirtual java.lang.management.ThreadInfo.getStackTrace:()[Ljava/lang/StackTraceElement;
astore 6
start local 6 11: new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
astore 7
start local 7 12: aload 6
dup
astore 11
arraylength
istore 10
iconst_0
istore 9
goto 24
StackMap locals: org.openjdk.jmh.profile.StackProfiler$SamplingTask java.lang.management.ThreadInfo[] java.lang.management.ThreadInfo int int java.lang.management.ThreadInfo[] java.lang.StackTraceElement[] java.util.List top int int java.lang.StackTraceElement[]
StackMap stack:
13: aload 11
iload 9
aaload
astore 8
start local 8 14: aload 8
invokevirtual java.lang.StackTraceElement.getClassName:()Ljava/lang/String;
astore 12
start local 12 15: aload 0
aload 12
invokevirtual org.openjdk.jmh.profile.StackProfiler$SamplingTask.isExcluded:(Ljava/lang/String;)Z
ifne 23
16: aload 7
new java.lang.StringBuilder
dup
aload 12
invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
bipush 46
invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
aload 8
invokevirtual java.lang.StackTraceElement.getMethodName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
17: aload 0
getfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.this$0:Lorg/openjdk/jmh/profile/StackProfiler;
getfield org.openjdk.jmh.profile.StackProfiler.sampleLine:Z
ifeq 18
new java.lang.StringBuilder
dup
ldc ":"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 8
invokevirtual java.lang.StackTraceElement.getLineNumber:()I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
goto 19
StackMap locals: org.openjdk.jmh.profile.StackProfiler$SamplingTask java.lang.management.ThreadInfo[] java.lang.management.ThreadInfo int int java.lang.management.ThreadInfo[] java.lang.StackTraceElement[] java.util.List java.lang.StackTraceElement int int java.lang.StackTraceElement[] java.lang.String
StackMap stack: java.util.List java.lang.StringBuilder
18: ldc ""
StackMap locals: org.openjdk.jmh.profile.StackProfiler$SamplingTask java.lang.management.ThreadInfo[] java.lang.management.ThreadInfo int int java.lang.management.ThreadInfo[] java.lang.StackTraceElement[] java.util.List java.lang.StackTraceElement int int java.lang.StackTraceElement[] java.lang.String
StackMap stack: java.util.List java.lang.StringBuilder java.lang.String
19: invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
20: invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
21: aload 7
invokeinterface java.util.List.size:()I
aload 0
getfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.this$0:Lorg/openjdk/jmh/profile/StackProfiler;
getfield org.openjdk.jmh.profile.StackProfiler.stackLines:I
if_icmplt 23
22: goto 25
end local 12 end local 8 23: StackMap locals: org.openjdk.jmh.profile.StackProfiler$SamplingTask java.lang.management.ThreadInfo[] java.lang.management.ThreadInfo int int java.lang.management.ThreadInfo[] java.lang.StackTraceElement[] java.util.List top int int java.lang.StackTraceElement[]
StackMap stack:
iinc 9 1
StackMap locals:
StackMap stack:
24: iload 9
iload 10
if_icmplt 13
25: StackMap locals: org.openjdk.jmh.profile.StackProfiler$SamplingTask java.lang.management.ThreadInfo[] java.lang.management.ThreadInfo int int java.lang.management.ThreadInfo[] java.lang.StackTraceElement[] java.util.List
StackMap stack:
aload 7
invokeinterface java.util.List.isEmpty:()Z
ifeq 27
26: aload 7
ldc "<stack is empty, everything is filtered?>"
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
27: StackMap locals:
StackMap stack:
aload 2
invokevirtual java.lang.management.ThreadInfo.getThreadState:()Ljava/lang/Thread$State;
astore 8
start local 8 28: aload 0
getfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.stacks:Ljava/util/Map;
aload 8
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.openjdk.jmh.util.Multiset
new org.openjdk.jmh.profile.StackProfiler$StackRecord
dup
aload 7
invokespecial org.openjdk.jmh.profile.StackProfiler$StackRecord.<init>:(Ljava/util/List;)V
invokeinterface org.openjdk.jmh.util.Multiset.add:(Ljava/lang/Object;)V
end local 8 end local 7 end local 6 end local 2 29: StackMap locals: org.openjdk.jmh.profile.StackProfiler$SamplingTask java.lang.management.ThreadInfo[] top int int java.lang.management.ThreadInfo[]
StackMap stack:
iinc 3 1
StackMap locals:
StackMap stack:
30: iload 3
iload 4
if_icmplt 3
31: getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
aload 0
getfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.this$0:Lorg/openjdk/jmh/profile/StackProfiler;
getfield org.openjdk.jmh.profile.StackProfiler.periodMsec:I
i2l
invokevirtual java.util.concurrent.TimeUnit.sleep:(J)V
32: goto 35
StackMap locals: org.openjdk.jmh.profile.StackProfiler$SamplingTask java.lang.management.ThreadInfo[]
StackMap stack: java.lang.InterruptedException
33: pop
34: return
end local 1 35: StackMap locals:
StackMap stack:
invokestatic java.lang.Thread.interrupted:()Z
ifeq 1
36: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 37 0 this Lorg/openjdk/jmh/profile/StackProfiler$SamplingTask;
2 35 1 infos [Ljava/lang/management/ThreadInfo;
4 29 2 info Ljava/lang/management/ThreadInfo;
6 8 6 ignore Ljava/lang/String;
11 29 6 stack [Ljava/lang/StackTraceElement;
12 29 7 lines Ljava/util/List<Ljava/lang/String;>;
14 23 8 l Ljava/lang/StackTraceElement;
15 23 12 className Ljava/lang/String;
28 29 8 state Ljava/lang/Thread$State;
Exception table:
from to target type
31 32 33 Class java.lang.InterruptedException
public void start();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.thread:Ljava/lang/Thread;
invokevirtual java.lang.Thread.start:()V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/openjdk/jmh/profile/StackProfiler$SamplingTask;
public void stop();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.thread:Ljava/lang/Thread;
invokevirtual java.lang.Thread.interrupt:()V
1: aload 0
getfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.thread:Ljava/lang/Thread;
invokevirtual java.lang.Thread.join:()V
2: goto 5
StackMap locals:
StackMap stack: java.lang.InterruptedException
3: pop
4: invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.interrupt:()V
5: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/openjdk/jmh/profile/StackProfiler$SamplingTask;
Exception table:
from to target type
1 2 3 Class java.lang.InterruptedException
private boolean isExcluded(java.lang.String);
descriptor: (Ljava/lang/String;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=4, args_size=2
start local 0 start local 1 0: aload 0
getfield org.openjdk.jmh.profile.StackProfiler$SamplingTask.this$0:Lorg/openjdk/jmh/profile/StackProfiler;
getfield org.openjdk.jmh.profile.StackProfiler.excludePackageNames:Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 3
goto 4
StackMap locals: org.openjdk.jmh.profile.StackProfiler$SamplingTask java.lang.String top java.util.Iterator
StackMap stack:
1: aload 3
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.String
astore 2
start local 2 2: aload 1
aload 2
invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
ifeq 4
3: iconst_1
ireturn
end local 2 4: StackMap locals:
StackMap stack:
aload 3
invokeinterface java.util.Iterator.hasNext:()Z
ifne 1
5: iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/openjdk/jmh/profile/StackProfiler$SamplingTask;
0 6 1 className Ljava/lang/String;
2 4 2 p Ljava/lang/String;
MethodParameters:
Name Flags
className
}
SourceFile: "StackProfiler.java"
NestHost: org.openjdk.jmh.profile.StackProfiler
InnerClasses:
public final State = java.lang.Thread$State of java.lang.Thread
public SamplingTask = org.openjdk.jmh.profile.StackProfiler$SamplingTask of org.openjdk.jmh.profile.StackProfiler
private StackRecord = org.openjdk.jmh.profile.StackProfiler$StackRecord of org.openjdk.jmh.profile.StackProfiler