abstract class org.openjdk.jmh.runner.BaseRunner
minor version: 0
major version: 59
flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
this_class: org.openjdk.jmh.runner.BaseRunner
super_class: java.lang.Object
{
private long projectedTotalTime;
descriptor: J
flags: (0x0002) ACC_PRIVATE
private long projectedRunningTime;
descriptor: J
flags: (0x0002) ACC_PRIVATE
private long actualRunningTime;
descriptor: J
flags: (0x0002) ACC_PRIVATE
private long benchmarkStart;
descriptor: J
flags: (0x0002) ACC_PRIVATE
protected final org.openjdk.jmh.runner.options.Options options;
descriptor: Lorg/openjdk/jmh/runner/options/Options;
flags: (0x0014) ACC_PROTECTED, ACC_FINAL
protected final org.openjdk.jmh.runner.format.OutputFormat out;
descriptor: Lorg/openjdk/jmh/runner/format/OutputFormat;
flags: (0x0014) ACC_PROTECTED, ACC_FINAL
private static volatile int[] $SWITCH_TABLE$org$openjdk$jmh$runner$ActionMode;
descriptor: [I
flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC
public void <init>(org.openjdk.jmh.runner.options.Options, org.openjdk.jmh.runner.format.OutputFormat);
descriptor: (Lorg/openjdk/jmh/runner/options/Options;Lorg/openjdk/jmh/runner/format/OutputFormat;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 1
ifnonnull 3
2: new java.lang.IllegalArgumentException
dup
ldc "Options is null."
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.runner.options.Options org.openjdk.jmh.runner.format.OutputFormat
StackMap stack:
aload 2
ifnonnull 5
4: new java.lang.IllegalArgumentException
dup
ldc "Handler is null."
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
5: StackMap locals:
StackMap stack:
aload 0
aload 1
putfield org.openjdk.jmh.runner.BaseRunner.options:Lorg/openjdk/jmh/runner/options/Options;
6: aload 0
aload 2
putfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
7: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lorg/openjdk/jmh/runner/BaseRunner;
0 8 1 options Lorg/openjdk/jmh/runner/options/Options;
0 8 2 handler Lorg/openjdk/jmh/runner/format/OutputFormat;
MethodParameters:
Name Flags
options
handler
protected void runBenchmarksForked(org.openjdk.jmh.runner.ActionPlan, org.openjdk.jmh.runner.IterationResultAcceptor);
descriptor: (Lorg/openjdk/jmh/runner/ActionPlan;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=7, args_size=3
start local 0 start local 1 start local 2 0: aload 1
invokevirtual org.openjdk.jmh.runner.ActionPlan.getActions:()Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 4
goto 5
StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.runner.ActionPlan org.openjdk.jmh.runner.IterationResultAcceptor top java.util.Iterator
StackMap stack:
1: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.openjdk.jmh.runner.Action
astore 3
start local 3 2: aload 3
invokevirtual org.openjdk.jmh.runner.Action.getParams:()Lorg/openjdk/jmh/infra/BenchmarkParams;
astore 5
start local 5 3: aload 3
invokevirtual org.openjdk.jmh.runner.Action.getMode:()Lorg/openjdk/jmh/runner/ActionMode;
astore 6
start local 6 4: aload 0
aload 5
aload 6
aload 2
invokevirtual org.openjdk.jmh.runner.BaseRunner.doSingle:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/runner/ActionMode;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
end local 6 end local 5 end local 3 5: StackMap locals:
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 1
6: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/openjdk/jmh/runner/BaseRunner;
0 7 1 actionPlan Lorg/openjdk/jmh/runner/ActionPlan;
0 7 2 acceptor Lorg/openjdk/jmh/runner/IterationResultAcceptor;
2 5 3 action Lorg/openjdk/jmh/runner/Action;
3 5 5 params Lorg/openjdk/jmh/infra/BenchmarkParams;
4 5 6 mode Lorg/openjdk/jmh/runner/ActionMode;
MethodParameters:
Name Flags
actionPlan
acceptor
protected org.openjdk.jmh.util.Multimap<org.openjdk.jmh.infra.BenchmarkParams, org.openjdk.jmh.results.BenchmarkResult> runBenchmarksEmbedded(org.openjdk.jmh.runner.ActionPlan);
descriptor: (Lorg/openjdk/jmh/runner/ActionPlan;)Lorg/openjdk/jmh/util/Multimap;
flags: (0x0004) ACC_PROTECTED
Code:
stack=5, locals=14, args_size=2
start local 0 start local 1 0: new org.openjdk.jmh.util.TreeMultimap
dup
invokespecial org.openjdk.jmh.util.TreeMultimap.<init>:()V
astore 2
start local 2 1: aload 1
invokevirtual org.openjdk.jmh.runner.ActionPlan.getActions:()Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 4
goto 24
StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.runner.ActionPlan org.openjdk.jmh.util.Multimap top java.util.Iterator
StackMap stack:
2: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.openjdk.jmh.runner.Action
astore 3
start local 3 3: aload 3
invokevirtual org.openjdk.jmh.runner.Action.getParams:()Lorg/openjdk/jmh/infra/BenchmarkParams;
astore 5
start local 5 4: aload 3
invokevirtual org.openjdk.jmh.runner.Action.getMode:()Lorg/openjdk/jmh/runner/ActionMode;
astore 6
start local 6 5: invokestatic java.lang.System.currentTimeMillis:()J
lstore 7
start local 7 6: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
aload 5
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.startBenchmark:(Lorg/openjdk/jmh/infra/BenchmarkParams;)V
7: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc ""
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
8: aload 0
invokevirtual org.openjdk.jmh.runner.BaseRunner.etaBeforeBenchmark:()V
9: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc "# Fork: N/A, test runs in the host VM"
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
10: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc "# *** WARNING: Non-forked runs may silently omit JVM options, mess up profilers, disable compiler hints, etc. ***"
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
11: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc "# *** WARNING: Use non-forked runs only for debugging purposes, not for actual performance runs. ***"
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
12: new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
astore 9
start local 9 13: new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
astore 10
start local 10 14: new org.openjdk.jmh.runner.BaseRunner$1
dup
aload 0
aload 9
aload 10
invokespecial org.openjdk.jmh.runner.BaseRunner$1.<init>:(Lorg/openjdk/jmh/runner/BaseRunner;Ljava/util/List;Ljava/util/List;)V
astore 11
start local 11 15: aload 0
aload 5
aload 6
aload 11
invokevirtual org.openjdk.jmh.runner.BaseRunner.doSingle:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/runner/ActionMode;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
16: aload 9
invokeinterface java.util.List.isEmpty:()Z
ifne 23
17: aload 10
iconst_0
invokeinterface java.util.List.get:(I)Ljava/lang/Object;
checkcast org.openjdk.jmh.results.BenchmarkResultMetaData
astore 12
start local 12 18: aload 12
ifnull 20
19: aload 12
lload 7
invokevirtual org.openjdk.jmh.results.BenchmarkResultMetaData.adjustStart:(J)V
20: StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.runner.ActionPlan org.openjdk.jmh.util.Multimap org.openjdk.jmh.runner.Action java.util.Iterator org.openjdk.jmh.infra.BenchmarkParams org.openjdk.jmh.runner.ActionMode long java.util.List java.util.List org.openjdk.jmh.runner.IterationResultAcceptor org.openjdk.jmh.results.BenchmarkResultMetaData
StackMap stack:
new org.openjdk.jmh.results.BenchmarkResult
dup
aload 5
aload 9
aload 12
invokespecial org.openjdk.jmh.results.BenchmarkResult.<init>:(Lorg/openjdk/jmh/infra/BenchmarkParams;Ljava/util/Collection;Lorg/openjdk/jmh/results/BenchmarkResultMetaData;)V
astore 13
start local 13 21: aload 2
aload 5
aload 13
invokeinterface org.openjdk.jmh.util.Multimap.put:(Ljava/lang/Object;Ljava/lang/Object;)V
22: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
aload 13
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.endBenchmark:(Lorg/openjdk/jmh/results/BenchmarkResult;)V
end local 13 end local 12 23: StackMap locals:
StackMap stack:
aload 0
aload 5
invokevirtual org.openjdk.jmh.runner.BaseRunner.etaAfterBenchmark:(Lorg/openjdk/jmh/infra/BenchmarkParams;)V
end local 11 end local 10 end local 9 end local 7 end local 6 end local 5 end local 3 24: StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.runner.ActionPlan org.openjdk.jmh.util.Multimap top java.util.Iterator
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 2
25: aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 26 0 this Lorg/openjdk/jmh/runner/BaseRunner;
0 26 1 actionPlan Lorg/openjdk/jmh/runner/ActionPlan;
1 26 2 results Lorg/openjdk/jmh/util/Multimap<Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/results/BenchmarkResult;>;
3 24 3 action Lorg/openjdk/jmh/runner/Action;
4 24 5 params Lorg/openjdk/jmh/infra/BenchmarkParams;
5 24 6 mode Lorg/openjdk/jmh/runner/ActionMode;
6 24 7 startTime J
13 24 9 res Ljava/util/List<Lorg/openjdk/jmh/results/IterationResult;>;
14 24 10 mds Ljava/util/List<Lorg/openjdk/jmh/results/BenchmarkResultMetaData;>;
15 24 11 acceptor Lorg/openjdk/jmh/runner/IterationResultAcceptor;
18 23 12 md Lorg/openjdk/jmh/results/BenchmarkResultMetaData;
21 23 13 br Lorg/openjdk/jmh/results/BenchmarkResult;
Signature: (Lorg/openjdk/jmh/runner/ActionPlan;)Lorg/openjdk/jmh/util/Multimap<Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/results/BenchmarkResult;>;
MethodParameters:
Name Flags
actionPlan
private void doSingle(org.openjdk.jmh.infra.BenchmarkParams, org.openjdk.jmh.runner.ActionMode, org.openjdk.jmh.runner.IterationResultAcceptor);
descriptor: (Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/runner/ActionMode;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=9, args_size=4
start local 0 start local 1 start local 2 start local 3 0: invokestatic org.openjdk.jmh.runner.BaseRunner.$SWITCH_TABLE$org$openjdk$jmh$runner$ActionMode:()[I
aload 2
invokevirtual org.openjdk.jmh.runner.ActionMode.ordinal:()I
iaload
tableswitch { // 2 - 4
2: 1
3: 4
4: 4
default: 6
}
1: StackMap locals:
StackMap stack:
aload 0
aload 1
aconst_null
invokevirtual org.openjdk.jmh.runner.BaseRunner.runBenchmark:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
2: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc ""
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
3: goto 18
4: StackMap locals:
StackMap stack:
aload 0
aload 1
aload 3
invokevirtual org.openjdk.jmh.runner.BaseRunner.runBenchmark:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
5: goto 18
6: StackMap locals:
StackMap stack:
new java.lang.IllegalStateException
dup
new java.lang.StringBuilder
dup
ldc "Unknown mode: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
7: StackMap locals:
StackMap stack: org.openjdk.jmh.runner.BenchmarkException
astore 4
start local 4 8: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc "<failure>"
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
9: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc ""
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
10: aload 4
invokevirtual org.openjdk.jmh.runner.BenchmarkException.getSuppressed:()[Ljava/lang/Throwable;
dup
astore 8
arraylength
istore 7
iconst_0
istore 6
goto 14
StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.infra.BenchmarkParams org.openjdk.jmh.runner.ActionMode org.openjdk.jmh.runner.IterationResultAcceptor org.openjdk.jmh.runner.BenchmarkException top int int java.lang.Throwable[]
StackMap stack:
11: aload 8
iload 6
aaload
astore 5
start local 5 12: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
aload 5
invokestatic org.openjdk.jmh.util.Utils.throwableToString:(Ljava/lang/Throwable;)Ljava/lang/String;
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
end local 5 13: iinc 6 1
StackMap locals:
StackMap stack:
14: iload 6
iload 7
if_icmplt 11
15: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc ""
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
16: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.options:Lorg/openjdk/jmh/runner/options/Options;
invokeinterface org.openjdk.jmh.runner.options.Options.shouldFailOnError:()Lorg/openjdk/jmh/util/Optional;
iconst_0
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
invokevirtual org.openjdk.jmh.util.Optional.orElse:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.lang.Boolean
invokevirtual java.lang.Boolean.booleanValue:()Z
ifeq 18
17: aload 4
athrow
end local 4 18: StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.infra.BenchmarkParams org.openjdk.jmh.runner.ActionMode org.openjdk.jmh.runner.IterationResultAcceptor
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lorg/openjdk/jmh/runner/BaseRunner;
0 19 1 params Lorg/openjdk/jmh/infra/BenchmarkParams;
0 19 2 mode Lorg/openjdk/jmh/runner/ActionMode;
0 19 3 acceptor Lorg/openjdk/jmh/runner/IterationResultAcceptor;
8 18 4 be Lorg/openjdk/jmh/runner/BenchmarkException;
12 13 5 cause Ljava/lang/Throwable;
Exception table:
from to target type
0 7 7 Class org.openjdk.jmh.runner.BenchmarkException
MethodParameters:
Name Flags
params
mode
acceptor
protected void etaAfterBenchmark(org.openjdk.jmh.infra.BenchmarkParams);
descriptor: (Lorg/openjdk/jmh/infra/BenchmarkParams;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=7, locals=4, args_size=2
start local 0 start local 1 0: invokestatic java.lang.System.nanoTime:()J
lstore 2
start local 2 1: aload 0
dup
getfield org.openjdk.jmh.runner.BaseRunner.projectedRunningTime:J
aload 0
aload 1
invokevirtual org.openjdk.jmh.runner.BaseRunner.estimateTimeSingleFork:(Lorg/openjdk/jmh/infra/BenchmarkParams;)J
ladd
putfield org.openjdk.jmh.runner.BaseRunner.projectedRunningTime:J
2: aload 0
dup
getfield org.openjdk.jmh.runner.BaseRunner.actualRunningTime:J
lload 2
aload 0
getfield org.openjdk.jmh.runner.BaseRunner.benchmarkStart:J
lsub
ladd
putfield org.openjdk.jmh.runner.BaseRunner.actualRunningTime:J
3: aload 0
lload 2
putfield org.openjdk.jmh.runner.BaseRunner.benchmarkStart:J
4: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/openjdk/jmh/runner/BaseRunner;
0 5 1 params Lorg/openjdk/jmh/infra/BenchmarkParams;
1 5 2 current J
MethodParameters:
Name Flags
params
protected void etaBeforeBenchmarks(java.util.Collection<org.openjdk.jmh.runner.ActionPlan>);
descriptor: (Ljava/util/Collection;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=7, locals=7, args_size=2
start local 0 start local 1 0: aload 0
lconst_0
putfield org.openjdk.jmh.runner.BaseRunner.projectedTotalTime:J
1: aload 1
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 3
goto 8
StackMap locals: org.openjdk.jmh.runner.BaseRunner java.util.Collection top java.util.Iterator
StackMap stack:
2: aload 3
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.openjdk.jmh.runner.ActionPlan
astore 2
start local 2 3: aload 2
invokevirtual org.openjdk.jmh.runner.ActionPlan.getActions:()Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 5
goto 7
StackMap locals: org.openjdk.jmh.runner.BaseRunner java.util.Collection org.openjdk.jmh.runner.ActionPlan java.util.Iterator top java.util.Iterator
StackMap stack:
4: aload 5
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.openjdk.jmh.runner.Action
astore 4
start local 4 5: aload 4
invokevirtual org.openjdk.jmh.runner.Action.getParams:()Lorg/openjdk/jmh/infra/BenchmarkParams;
astore 6
start local 6 6: aload 0
dup
getfield org.openjdk.jmh.runner.BaseRunner.projectedTotalTime:J
iconst_1
aload 6
invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getForks:()I
invokestatic java.lang.Math.max:(II)I
aload 6
invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getWarmupForks:()I
iadd
i2l
aload 0
aload 6
invokevirtual org.openjdk.jmh.runner.BaseRunner.estimateTimeSingleFork:(Lorg/openjdk/jmh/infra/BenchmarkParams;)J
lmul
ladd
putfield org.openjdk.jmh.runner.BaseRunner.projectedTotalTime:J
end local 6 end local 4 7: StackMap locals:
StackMap stack:
aload 5
invokeinterface java.util.Iterator.hasNext:()Z
ifne 4
end local 2 8: StackMap locals: org.openjdk.jmh.runner.BaseRunner java.util.Collection top java.util.Iterator
StackMap stack:
aload 3
invokeinterface java.util.Iterator.hasNext:()Z
ifne 2
9: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/openjdk/jmh/runner/BaseRunner;
0 10 1 plans Ljava/util/Collection<Lorg/openjdk/jmh/runner/ActionPlan;>;
3 8 2 plan Lorg/openjdk/jmh/runner/ActionPlan;
5 7 4 act Lorg/openjdk/jmh/runner/Action;
6 7 6 params Lorg/openjdk/jmh/infra/BenchmarkParams;
Signature: (Ljava/util/Collection<Lorg/openjdk/jmh/runner/ActionPlan;>;)V
MethodParameters:
Name Flags
plans
private long estimateTimeSingleFork(org.openjdk.jmh.infra.BenchmarkParams);
descriptor: (Lorg/openjdk/jmh/infra/BenchmarkParams;)J
flags: (0x0002) ACC_PRIVATE
Code:
stack=6, locals=6, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getWarmup:()Lorg/openjdk/jmh/infra/IterationParams;
astore 2
start local 2 1: aload 1
invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getMeasurement:()Lorg/openjdk/jmh/infra/IterationParams;
astore 3
start local 3 2: aload 1
invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getMode:()Lorg/openjdk/jmh/annotations/Mode;
getstatic org.openjdk.jmh.annotations.Mode.SingleShotTime:Lorg/openjdk/jmh/annotations/Mode;
if_acmpne 5
3: aload 2
invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
aload 3
invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
iadd
i2l
getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
lconst_1
invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
lmul
lstore 4
start local 4 4: goto 9
end local 4 5: StackMap locals: org.openjdk.jmh.infra.IterationParams org.openjdk.jmh.infra.IterationParams
StackMap stack:
aload 2
invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
i2l
aload 2
invokevirtual org.openjdk.jmh.infra.IterationParams.getTime:()Lorg/openjdk/jmh/runner/options/TimeValue;
getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
invokevirtual org.openjdk.jmh.runner.options.TimeValue.convertTo:(Ljava/util/concurrent/TimeUnit;)J
lmul
6: aload 3
invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
i2l
aload 3
invokevirtual org.openjdk.jmh.infra.IterationParams.getTime:()Lorg/openjdk/jmh/runner/options/TimeValue;
getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
invokevirtual org.openjdk.jmh.runner.options.TimeValue.convertTo:(Ljava/util/concurrent/TimeUnit;)J
lmul
7: ladd
8: lstore 4
start local 4 9: StackMap locals: long
StackMap stack:
lload 4
lreturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/openjdk/jmh/runner/BaseRunner;
0 10 1 params Lorg/openjdk/jmh/infra/BenchmarkParams;
1 10 2 wp Lorg/openjdk/jmh/infra/IterationParams;
2 10 3 mp Lorg/openjdk/jmh/infra/IterationParams;
4 5 4 estimatedTime J
9 10 4 estimatedTime J
MethodParameters:
Name Flags
params
protected void etaBeforeBenchmark();
descriptor: ()V
flags: (0x0004) ACC_PROTECTED
Code:
stack=9, locals=5, args_size=1
start local 0 0: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.benchmarkStart:J
lconst_0
lcmp
ifne 2
1: aload 0
invokestatic java.lang.System.nanoTime:()J
putfield org.openjdk.jmh.runner.BaseRunner.benchmarkStart:J
2: StackMap locals:
StackMap stack:
dconst_1
aload 0
getfield org.openjdk.jmh.runner.BaseRunner.projectedRunningTime:J
l2d
dmul
aload 0
getfield org.openjdk.jmh.runner.BaseRunner.projectedTotalTime:J
l2d
ddiv
dstore 3
start local 3 3: dload 3
dconst_0
dcmpl
ifeq 6
4: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.actualRunningTime:J
l2d
dconst_1
dload 3
ddiv
dconst_1
dsub
dmul
d2l
lstore 1
start local 1 5: goto 7
end local 1 6: StackMap locals: org.openjdk.jmh.runner.BaseRunner top top double
StackMap stack:
aload 0
getfield org.openjdk.jmh.runner.BaseRunner.projectedTotalTime:J
lstore 1
start local 1 7: StackMap locals: org.openjdk.jmh.runner.BaseRunner long double
StackMap stack:
aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc "# Run progress: %.2f%% complete, ETA %s"
iconst_2
anewarray java.lang.Object
dup
iconst_0
dload 3
ldc 100.0
dmul
invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
aastore
dup
iconst_1
aload 0
lload 1
invokevirtual org.openjdk.jmh.runner.BaseRunner.formatDuration:(J)Ljava/lang/String;
aastore
invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
8: return
end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/openjdk/jmh/runner/BaseRunner;
5 6 1 totalETA J
7 9 1 totalETA J
3 9 3 partsDone D
protected void etaAfterBenchmarks();
descriptor: ()V
flags: (0x0004) ACC_PROTECTED
Code:
stack=8, locals=1, args_size=1
start local 0 0: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc "# Run complete. Total time: %s"
iconst_1
anewarray java.lang.Object
dup
iconst_0
aload 0
aload 0
getfield org.openjdk.jmh.runner.BaseRunner.actualRunningTime:J
invokevirtual org.openjdk.jmh.runner.BaseRunner.formatDuration:(J)Ljava/lang/String;
aastore
invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
1: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc ""
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
2: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/openjdk/jmh/runner/BaseRunner;
private java.lang.String formatDuration(long);
descriptor: (J)Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=8, locals=11, args_size=2
start local 0 start local 1 0: getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
lload 1
invokevirtual java.util.concurrent.TimeUnit.toDays:(J)J
lstore 3
start local 3 1: lload 1
lload 3
getstatic java.util.concurrent.TimeUnit.DAYS:Ljava/util/concurrent/TimeUnit;
lconst_1
invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
lmul
lsub
lstore 1
2: getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
lload 1
invokevirtual java.util.concurrent.TimeUnit.toHours:(J)J
lstore 5
start local 5 3: lload 1
lload 5
getstatic java.util.concurrent.TimeUnit.HOURS:Ljava/util/concurrent/TimeUnit;
lconst_1
invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
lmul
lsub
lstore 1
4: getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
lload 1
invokevirtual java.util.concurrent.TimeUnit.toMinutes:(J)J
lstore 7
start local 7 5: lload 1
lload 7
getstatic java.util.concurrent.TimeUnit.MINUTES:Ljava/util/concurrent/TimeUnit;
lconst_1
invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
lmul
lsub
lstore 1
6: getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
lload 1
invokevirtual java.util.concurrent.TimeUnit.toSeconds:(J)J
lstore 9
start local 9 7: ldc "%s%02d:%02d:%02d"
iconst_4
anewarray java.lang.Object
dup
iconst_0
lload 3
lconst_0
lcmp
ifle 8
new java.lang.StringBuilder
dup
lload 3
invokestatic java.lang.String.valueOf:(J)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
ldc " days, "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
goto 9
StackMap locals: org.openjdk.jmh.runner.BaseRunner long long long long long
StackMap stack: java.lang.String java.lang.Object[] java.lang.Object[] int
8: ldc ""
StackMap locals: org.openjdk.jmh.runner.BaseRunner long long long long long
StackMap stack: java.lang.String java.lang.Object[] java.lang.Object[] int java.lang.String
9: aastore
dup
iconst_1
lload 5
invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
aastore
dup
iconst_2
lload 7
invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
aastore
dup
iconst_3
lload 9
invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
aastore
invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
areturn
end local 9 end local 7 end local 5 end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/openjdk/jmh/runner/BaseRunner;
0 10 1 nanos J
1 10 3 days J
3 10 5 hrs J
5 10 7 mins J
7 10 9 secs J
MethodParameters:
Name Flags
nanos
void runBenchmark(org.openjdk.jmh.infra.BenchmarkParams, org.openjdk.jmh.runner.IterationResultAcceptor);
descriptor: (Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
flags: (0x0000)
Code:
stack=5, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aconst_null
astore 3
start local 3 1: new org.openjdk.jmh.runner.BenchmarkHandler
dup
aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
aload 0
getfield org.openjdk.jmh.runner.BaseRunner.options:Lorg/openjdk/jmh/runner/options/Options;
aload 1
invokespecial org.openjdk.jmh.runner.BenchmarkHandler.<init>:(Lorg/openjdk/jmh/runner/format/OutputFormat;Lorg/openjdk/jmh/runner/options/Options;Lorg/openjdk/jmh/infra/BenchmarkParams;)V
astore 3
2: aload 0
aload 1
aload 3
aload 2
invokevirtual org.openjdk.jmh.runner.BaseRunner.runBenchmark:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/runner/BenchmarkHandler;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
3: goto 12
StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.infra.BenchmarkParams org.openjdk.jmh.runner.IterationResultAcceptor org.openjdk.jmh.runner.BenchmarkHandler
StackMap stack: org.openjdk.jmh.runner.BenchmarkException
4: astore 4
start local 4 5: aload 4
athrow
end local 4 6: StackMap locals:
StackMap stack: java.lang.Throwable
astore 4
start local 4 7: new org.openjdk.jmh.runner.BenchmarkException
dup
aload 4
invokespecial org.openjdk.jmh.runner.BenchmarkException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 4 8: StackMap locals:
StackMap stack: java.lang.Throwable
astore 5
9: aload 3
ifnull 11
10: aload 3
invokevirtual org.openjdk.jmh.runner.BenchmarkHandler.shutdown:()V
11: StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.infra.BenchmarkParams org.openjdk.jmh.runner.IterationResultAcceptor org.openjdk.jmh.runner.BenchmarkHandler top java.lang.Throwable
StackMap stack:
aload 5
athrow
12: StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.infra.BenchmarkParams org.openjdk.jmh.runner.IterationResultAcceptor org.openjdk.jmh.runner.BenchmarkHandler
StackMap stack:
aload 3
ifnull 14
13: aload 3
invokevirtual org.openjdk.jmh.runner.BenchmarkHandler.shutdown:()V
14: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lorg/openjdk/jmh/runner/BaseRunner;
0 15 1 benchParams Lorg/openjdk/jmh/infra/BenchmarkParams;
0 15 2 acceptor Lorg/openjdk/jmh/runner/IterationResultAcceptor;
1 15 3 handler Lorg/openjdk/jmh/runner/BenchmarkHandler;
5 6 4 be Lorg/openjdk/jmh/runner/BenchmarkException;
7 8 4 ex Ljava/lang/Throwable;
Exception table:
from to target type
1 3 4 Class org.openjdk.jmh.runner.BenchmarkException
1 3 6 Class java.lang.Throwable
1 8 8 any
MethodParameters:
Name Flags
benchParams
acceptor
protected void runBenchmark(org.openjdk.jmh.infra.BenchmarkParams, org.openjdk.jmh.runner.BenchmarkHandler, org.openjdk.jmh.runner.IterationResultAcceptor);
descriptor: (Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/runner/BenchmarkHandler;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=12, locals=17, args_size=4
start local 0 start local 1 start local 2 start local 3 0: invokestatic java.lang.System.currentTimeMillis:()J
lstore 4
start local 4 1: lconst_0
lstore 6
start local 6 2: lconst_0
lstore 8
start local 8 3: aload 1
invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getWarmup:()Lorg/openjdk/jmh/infra/IterationParams;
astore 10
start local 10 4: iconst_1
istore 11
start local 11 5: goto 16
6: StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.infra.BenchmarkParams org.openjdk.jmh.runner.BenchmarkHandler org.openjdk.jmh.runner.IterationResultAcceptor long long long org.openjdk.jmh.infra.IterationParams int
StackMap stack:
aload 0
invokevirtual org.openjdk.jmh.runner.BaseRunner.runSystemGC:()Z
ifeq 8
7: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc "System.gc() executed"
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.verbosePrintln:(Ljava/lang/String;)V
8: StackMap locals:
StackMap stack:
aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
aload 1
aload 10
iload 11
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.iteration:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/infra/IterationParams;I)V
9: aload 1
invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getMeasurement:()Lorg/openjdk/jmh/infra/IterationParams;
invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
ifne 10
iconst_1
goto 11
StackMap locals:
StackMap stack:
10: iconst_0
StackMap locals:
StackMap stack: int
11: istore 12
start local 12 12: aload 2
aload 1
aload 10
iload 12
invokevirtual org.openjdk.jmh.runner.BenchmarkHandler.runIteration:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/infra/IterationParams;Z)Lorg/openjdk/jmh/results/IterationResult;
astore 13
start local 13 13: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
aload 1
aload 10
iload 11
aload 13
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.iterationResult:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/infra/IterationParams;ILorg/openjdk/jmh/results/IterationResult;)V
14: lload 6
aload 13
invokevirtual org.openjdk.jmh.results.IterationResult.getMetadata:()Lorg/openjdk/jmh/results/IterationResultMetaData;
invokevirtual org.openjdk.jmh.results.IterationResultMetaData.getAllOps:()J
ladd
lstore 6
end local 13 end local 12 15: iinc 11 1
StackMap locals:
StackMap stack:
16: iload 11
aload 10
invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
if_icmple 6
end local 11 17: invokestatic java.lang.System.currentTimeMillis:()J
lstore 11
start local 11 18: aload 1
invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getMeasurement:()Lorg/openjdk/jmh/infra/IterationParams;
astore 13
start local 13 19: iconst_1
istore 14
start local 14 20: goto 33
21: StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.infra.BenchmarkParams org.openjdk.jmh.runner.BenchmarkHandler org.openjdk.jmh.runner.IterationResultAcceptor long long long org.openjdk.jmh.infra.IterationParams long org.openjdk.jmh.infra.IterationParams int
StackMap stack:
aload 0
invokevirtual org.openjdk.jmh.runner.BaseRunner.runSystemGC:()Z
ifeq 23
22: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc "System.gc() executed"
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.verbosePrintln:(Ljava/lang/String;)V
23: StackMap locals:
StackMap stack:
aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
aload 1
aload 13
iload 14
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.iteration:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/infra/IterationParams;I)V
24: iload 14
aload 13
invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
if_icmpne 25
iconst_1
goto 26
StackMap locals:
StackMap stack:
25: iconst_0
StackMap locals:
StackMap stack: int
26: istore 15
start local 15 27: aload 2
aload 1
aload 13
iload 15
invokevirtual org.openjdk.jmh.runner.BenchmarkHandler.runIteration:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/infra/IterationParams;Z)Lorg/openjdk/jmh/results/IterationResult;
astore 16
start local 16 28: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
aload 1
aload 13
iload 14
aload 16
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.iterationResult:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/infra/IterationParams;ILorg/openjdk/jmh/results/IterationResult;)V
29: lload 8
aload 16
invokevirtual org.openjdk.jmh.results.IterationResult.getMetadata:()Lorg/openjdk/jmh/results/IterationResultMetaData;
invokevirtual org.openjdk.jmh.results.IterationResultMetaData.getAllOps:()J
ladd
lstore 8
30: aload 3
ifnull 32
31: aload 3
aload 16
invokeinterface org.openjdk.jmh.runner.IterationResultAcceptor.accept:(Lorg/openjdk/jmh/results/IterationResult;)V
end local 16 end local 15 32: StackMap locals:
StackMap stack:
iinc 14 1
StackMap locals:
StackMap stack:
33: iload 14
aload 13
invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
if_icmple 21
end local 14 34: invokestatic java.lang.System.currentTimeMillis:()J
lstore 14
start local 14 35: new org.openjdk.jmh.results.BenchmarkResultMetaData
dup
36: lload 4
lload 11
lload 14
37: lload 6
lload 8
38: invokespecial org.openjdk.jmh.results.BenchmarkResultMetaData.<init>:(JJJJJ)V
astore 16
start local 16 39: aload 3
ifnull 41
40: aload 3
aload 16
invokeinterface org.openjdk.jmh.runner.IterationResultAcceptor.acceptMeta:(Lorg/openjdk/jmh/results/BenchmarkResultMetaData;)V
41: StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.infra.BenchmarkParams org.openjdk.jmh.runner.BenchmarkHandler org.openjdk.jmh.runner.IterationResultAcceptor long long long org.openjdk.jmh.infra.IterationParams long org.openjdk.jmh.infra.IterationParams long org.openjdk.jmh.results.BenchmarkResultMetaData
StackMap stack:
return
end local 16 end local 14 end local 13 end local 11 end local 10 end local 8 end local 6 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 42 0 this Lorg/openjdk/jmh/runner/BaseRunner;
0 42 1 benchParams Lorg/openjdk/jmh/infra/BenchmarkParams;
0 42 2 handler Lorg/openjdk/jmh/runner/BenchmarkHandler;
0 42 3 acceptor Lorg/openjdk/jmh/runner/IterationResultAcceptor;
1 42 4 warmupTime J
2 42 6 allWarmup J
3 42 8 allMeasurement J
4 42 10 wp Lorg/openjdk/jmh/infra/IterationParams;
5 17 11 i I
12 15 12 isLastIteration Z
13 15 13 ir Lorg/openjdk/jmh/results/IterationResult;
18 42 11 measurementTime J
19 42 13 mp Lorg/openjdk/jmh/infra/IterationParams;
20 34 14 i I
27 32 15 isLastIteration Z
28 32 16 ir Lorg/openjdk/jmh/results/IterationResult;
35 42 14 stopTime J
39 42 16 md Lorg/openjdk/jmh/results/BenchmarkResultMetaData;
MethodParameters:
Name Flags
benchParams
handler
acceptor
public boolean runSystemGC();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=11, args_size=1
start local 0 0: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.options:Lorg/openjdk/jmh/runner/options/Options;
invokeinterface org.openjdk.jmh.runner.options.Options.shouldDoGC:()Lorg/openjdk/jmh/util/Optional;
iconst_0
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
invokevirtual org.openjdk.jmh.util.Optional.orElse:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.lang.Boolean
invokevirtual java.lang.Boolean.booleanValue:()Z
ifeq 49
1: new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
astore 1
start local 1 2: lconst_0
lstore 2
start local 2 3: invokestatic java.lang.management.ManagementFactory.getGarbageCollectorMXBeans:()Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 5
goto 8
StackMap locals: org.openjdk.jmh.runner.BaseRunner java.util.List long top java.util.Iterator
StackMap stack:
4: aload 5
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.management.GarbageCollectorMXBean
astore 4
start local 4 5: aload 4
invokeinterface java.lang.management.GarbageCollectorMXBean.getCollectionCount:()J
lstore 6
start local 6 6: lload 6
ldc -1
lcmp
ifeq 8
7: aload 1
aload 4
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
end local 6 end local 4 8: StackMap locals:
StackMap stack:
aload 5
invokeinterface java.util.Iterator.hasNext:()Z
ifne 4
9: aload 1
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 5
goto 12
StackMap locals:
StackMap stack:
10: aload 5
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.management.GarbageCollectorMXBean
astore 4
start local 4 11: lload 2
aload 4
invokeinterface java.lang.management.GarbageCollectorMXBean.getCollectionCount:()J
ladd
lstore 2
end local 4 12: StackMap locals:
StackMap stack:
aload 5
invokeinterface java.util.Iterator.hasNext:()Z
ifne 10
13: invokestatic java.lang.System.runFinalization:()V
14: invokestatic java.lang.System.gc:()V
15: invokestatic java.lang.System.runFinalization:()V
16: invokestatic java.lang.System.gc:()V
17: aload 1
invokeinterface java.util.List.isEmpty:()Z
ifeq 24
18: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc "WARNING: MXBeans can not report GC info. System.gc() invoked, pessimistically waiting 20000 msecs"
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
19: getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
ldc 20000
invokevirtual java.util.concurrent.TimeUnit.sleep:(J)V
20: goto 23
StackMap locals: org.openjdk.jmh.runner.BaseRunner java.util.List long
StackMap stack: java.lang.InterruptedException
21: pop
22: invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.interrupt:()V
23: StackMap locals:
StackMap stack:
iconst_1
ireturn
24: StackMap locals:
StackMap stack:
iconst_0
istore 4
start local 4 25: invokestatic java.lang.System.nanoTime:()J
lstore 5
start local 5 26: goto 43
27: StackMap locals: int long
StackMap stack:
getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
ldc 200
invokevirtual java.util.concurrent.TimeUnit.sleep:(J)V
28: goto 31
StackMap locals:
StackMap stack: java.lang.InterruptedException
29: pop
30: invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.interrupt:()V
31: StackMap locals:
StackMap stack:
lconst_0
lstore 7
start local 7 32: aload 1
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 10
goto 35
StackMap locals: org.openjdk.jmh.runner.BaseRunner java.util.List long int long long top java.util.Iterator
StackMap stack:
33: aload 10
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.management.GarbageCollectorMXBean
astore 9
start local 9 34: lload 7
aload 9
invokeinterface java.lang.management.GarbageCollectorMXBean.getCollectionCount:()J
ladd
lstore 7
end local 9 35: StackMap locals:
StackMap stack:
aload 10
invokeinterface java.util.Iterator.hasNext:()Z
ifne 33
36: iload 4
ifne 40
37: lload 7
lload 2
lsub
ldc 2
lcmp
iflt 43
38: iconst_1
istore 4
39: goto 43
40: StackMap locals: org.openjdk.jmh.runner.BaseRunner java.util.List long int long long
StackMap stack:
lload 7
lload 2
lcmp
ifne 42
41: iconst_1
ireturn
42: StackMap locals:
StackMap stack:
lload 7
lstore 2
end local 7 43: StackMap locals:
StackMap stack:
getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
invokestatic java.lang.System.nanoTime:()J
lload 5
lsub
invokevirtual java.util.concurrent.TimeUnit.toMillis:(J)J
ldc 20000
lcmp
iflt 27
44: iload 4
ifeq 47
45: aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc "WARNING: System.gc() was invoked but unable to wait while GC stopped, is GC too asynchronous?"
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
46: goto 48
47: StackMap locals:
StackMap stack:
aload 0
getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
ldc "WARNING: System.gc() was invoked but couldn't detect a GC occurring, is System.gc() disabled?"
invokeinterface org.openjdk.jmh.runner.format.OutputFormat.println:(Ljava/lang/String;)V
48: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 5 end local 4 end local 2 end local 1 49: StackMap locals: org.openjdk.jmh.runner.BaseRunner
StackMap stack:
iconst_0
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 50 0 this Lorg/openjdk/jmh/runner/BaseRunner;
2 49 1 enabledBeans Ljava/util/List<Ljava/lang/management/GarbageCollectorMXBean;>;
3 49 2 beforeGcCount J
5 8 4 bean Ljava/lang/management/GarbageCollectorMXBean;
6 8 6 count J
11 12 4 bean Ljava/lang/management/GarbageCollectorMXBean;
25 49 4 gcHappened Z
26 49 5 start J
32 43 7 afterGcCount J
34 35 9 bean Ljava/lang/management/GarbageCollectorMXBean;
Exception table:
from to target type
19 20 21 Class java.lang.InterruptedException
27 28 29 Class java.lang.InterruptedException
static int[] $SWITCH_TABLE$org$openjdk$jmh$runner$ActionMode();
descriptor: ()[I
flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
Code:
stack=3, locals=1, args_size=0
0: getstatic org.openjdk.jmh.runner.BaseRunner.$SWITCH_TABLE$org$openjdk$jmh$runner$ActionMode:[I
dup
ifnull 1
areturn
StackMap locals:
StackMap stack: int[]
1: pop
invokestatic org.openjdk.jmh.runner.ActionMode.values:()[Lorg/openjdk/jmh/runner/ActionMode;
arraylength
newarray 10
astore 0
2: aload 0
getstatic org.openjdk.jmh.runner.ActionMode.MEASUREMENT:Lorg/openjdk/jmh/runner/ActionMode;
invokevirtual org.openjdk.jmh.runner.ActionMode.ordinal:()I
iconst_3
iastore
3: goto 5
StackMap locals: int[]
StackMap stack: java.lang.NoSuchFieldError
4: pop
StackMap locals:
StackMap stack:
5: aload 0
getstatic org.openjdk.jmh.runner.ActionMode.UNDEF:Lorg/openjdk/jmh/runner/ActionMode;
invokevirtual org.openjdk.jmh.runner.ActionMode.ordinal:()I
iconst_1
iastore
6: goto 8
StackMap locals:
StackMap stack: java.lang.NoSuchFieldError
7: pop
StackMap locals:
StackMap stack:
8: aload 0
getstatic org.openjdk.jmh.runner.ActionMode.WARMUP:Lorg/openjdk/jmh/runner/ActionMode;
invokevirtual org.openjdk.jmh.runner.ActionMode.ordinal:()I
iconst_2
iastore
9: goto 11
StackMap locals:
StackMap stack: java.lang.NoSuchFieldError
10: pop
StackMap locals:
StackMap stack:
11: aload 0
getstatic org.openjdk.jmh.runner.ActionMode.WARMUP_MEASUREMENT:Lorg/openjdk/jmh/runner/ActionMode;
invokevirtual org.openjdk.jmh.runner.ActionMode.ordinal:()I
iconst_4
iastore
12: goto 14
StackMap locals:
StackMap stack: java.lang.NoSuchFieldError
13: pop
StackMap locals:
StackMap stack:
14: aload 0
dup
putstatic org.openjdk.jmh.runner.BaseRunner.$SWITCH_TABLE$org$openjdk$jmh$runner$ActionMode:[I
areturn
LocalVariableTable:
Start End Slot Name Signature
Exception table:
from to target type
2 3 4 Class java.lang.NoSuchFieldError
5 6 7 Class java.lang.NoSuchFieldError
8 9 10 Class java.lang.NoSuchFieldError
11 12 13 Class java.lang.NoSuchFieldError
}
SourceFile: "BaseRunner.java"
NestMembers:
org.openjdk.jmh.runner.BaseRunner$1
InnerClasses:
org.openjdk.jmh.runner.BaseRunner$1