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 // org.openjdk.jmh.runner.BaseRunner this
        start local 1 // org.openjdk.jmh.runner.options.Options options
        start local 2 // org.openjdk.jmh.runner.format.OutputFormat handler
         0: .line 60
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 61
            aload 1 /* options */
            ifnonnull 3
         2: .line 62
            new java.lang.IllegalArgumentException
            dup
            ldc "Options is null."
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 64
      StackMap locals: org.openjdk.jmh.runner.BaseRunner org.openjdk.jmh.runner.options.Options org.openjdk.jmh.runner.format.OutputFormat
      StackMap stack:
            aload 2 /* handler */
            ifnonnull 5
         4: .line 65
            new java.lang.IllegalArgumentException
            dup
            ldc "Handler is null."
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 67
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* options */
            putfield org.openjdk.jmh.runner.BaseRunner.options:Lorg/openjdk/jmh/runner/options/Options;
         6: .line 68
            aload 0 /* this */
            aload 2 /* handler */
            putfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
         7: .line 69
            return
        end local 2 // org.openjdk.jmh.runner.format.OutputFormat handler
        end local 1 // org.openjdk.jmh.runner.options.Options options
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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 // org.openjdk.jmh.runner.BaseRunner this
        start local 1 // org.openjdk.jmh.runner.ActionPlan actionPlan
        start local 2 // org.openjdk.jmh.runner.IterationResultAcceptor acceptor
         0: .line 72
            aload 1 /* actionPlan */
            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 /* action */
        start local 3 // org.openjdk.jmh.runner.Action action
         2: .line 73
            aload 3 /* action */
            invokevirtual org.openjdk.jmh.runner.Action.getParams:()Lorg/openjdk/jmh/infra/BenchmarkParams;
            astore 5 /* params */
        start local 5 // org.openjdk.jmh.infra.BenchmarkParams params
         3: .line 74
            aload 3 /* action */
            invokevirtual org.openjdk.jmh.runner.Action.getMode:()Lorg/openjdk/jmh/runner/ActionMode;
            astore 6 /* mode */
        start local 6 // org.openjdk.jmh.runner.ActionMode mode
         4: .line 76
            aload 0 /* this */
            aload 5 /* params */
            aload 6 /* mode */
            aload 2 /* acceptor */
            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 // org.openjdk.jmh.runner.ActionMode mode
        end local 5 // org.openjdk.jmh.infra.BenchmarkParams params
        end local 3 // org.openjdk.jmh.runner.Action action
         5: .line 72
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         6: .line 78
            return
        end local 2 // org.openjdk.jmh.runner.IterationResultAcceptor acceptor
        end local 1 // org.openjdk.jmh.runner.ActionPlan actionPlan
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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 // org.openjdk.jmh.runner.BaseRunner this
        start local 1 // org.openjdk.jmh.runner.ActionPlan actionPlan
         0: .line 81
            new org.openjdk.jmh.util.TreeMultimap
            dup
            invokespecial org.openjdk.jmh.util.TreeMultimap.<init>:()V
            astore 2 /* results */
        start local 2 // org.openjdk.jmh.util.Multimap results
         1: .line 83
            aload 1 /* actionPlan */
            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 /* action */
        start local 3 // org.openjdk.jmh.runner.Action action
         3: .line 84
            aload 3 /* action */
            invokevirtual org.openjdk.jmh.runner.Action.getParams:()Lorg/openjdk/jmh/infra/BenchmarkParams;
            astore 5 /* params */
        start local 5 // org.openjdk.jmh.infra.BenchmarkParams params
         4: .line 85
            aload 3 /* action */
            invokevirtual org.openjdk.jmh.runner.Action.getMode:()Lorg/openjdk/jmh/runner/ActionMode;
            astore 6 /* mode */
        start local 6 // org.openjdk.jmh.runner.ActionMode mode
         5: .line 87
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 7 /* startTime */
        start local 7 // long startTime
         6: .line 89
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
            aload 5 /* params */
            invokeinterface org.openjdk.jmh.runner.format.OutputFormat.startBenchmark:(Lorg/openjdk/jmh/infra/BenchmarkParams;)V
         7: .line 90
            aload 0 /* this */
            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: .line 91
            aload 0 /* this */
            invokevirtual org.openjdk.jmh.runner.BaseRunner.etaBeforeBenchmark:()V
         9: .line 92
            aload 0 /* this */
            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: .line 93
            aload 0 /* this */
            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: .line 94
            aload 0 /* this */
            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: .line 96
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 9 /* res */
        start local 9 // java.util.List res
        13: .line 97
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 10 /* mds */
        start local 10 // java.util.List mds
        14: .line 99
            new org.openjdk.jmh.runner.BaseRunner$1
            dup
            aload 0 /* this */
            aload 9 /* res */
            aload 10 /* mds */
            invokespecial org.openjdk.jmh.runner.BaseRunner$1.<init>:(Lorg/openjdk/jmh/runner/BaseRunner;Ljava/util/List;Ljava/util/List;)V
            astore 11 /* acceptor */
        start local 11 // org.openjdk.jmh.runner.IterationResultAcceptor acceptor
        15: .line 111
            aload 0 /* this */
            aload 5 /* params */
            aload 6 /* mode */
            aload 11 /* acceptor */
            invokevirtual org.openjdk.jmh.runner.BaseRunner.doSingle:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/runner/ActionMode;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
        16: .line 113
            aload 9 /* res */
            invokeinterface java.util.List.isEmpty:()Z
            ifne 23
        17: .line 114
            aload 10 /* mds */
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast org.openjdk.jmh.results.BenchmarkResultMetaData
            astore 12 /* md */
        start local 12 // org.openjdk.jmh.results.BenchmarkResultMetaData md
        18: .line 115
            aload 12 /* md */
            ifnull 20
        19: .line 116
            aload 12 /* md */
            lload 7 /* startTime */
            invokevirtual org.openjdk.jmh.results.BenchmarkResultMetaData.adjustStart:(J)V
        20: .line 119
      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 /* params */
            aload 9 /* res */
            aload 12 /* md */
            invokespecial org.openjdk.jmh.results.BenchmarkResult.<init>:(Lorg/openjdk/jmh/infra/BenchmarkParams;Ljava/util/Collection;Lorg/openjdk/jmh/results/BenchmarkResultMetaData;)V
            astore 13 /* br */
        start local 13 // org.openjdk.jmh.results.BenchmarkResult br
        21: .line 120
            aload 2 /* results */
            aload 5 /* params */
            aload 13 /* br */
            invokeinterface org.openjdk.jmh.util.Multimap.put:(Ljava/lang/Object;Ljava/lang/Object;)V
        22: .line 121
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
            aload 13 /* br */
            invokeinterface org.openjdk.jmh.runner.format.OutputFormat.endBenchmark:(Lorg/openjdk/jmh/results/BenchmarkResult;)V
        end local 13 // org.openjdk.jmh.results.BenchmarkResult br
        end local 12 // org.openjdk.jmh.results.BenchmarkResultMetaData md
        23: .line 124
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 5 /* params */
            invokevirtual org.openjdk.jmh.runner.BaseRunner.etaAfterBenchmark:(Lorg/openjdk/jmh/infra/BenchmarkParams;)V
        end local 11 // org.openjdk.jmh.runner.IterationResultAcceptor acceptor
        end local 10 // java.util.List mds
        end local 9 // java.util.List res
        end local 7 // long startTime
        end local 6 // org.openjdk.jmh.runner.ActionMode mode
        end local 5 // org.openjdk.jmh.infra.BenchmarkParams params
        end local 3 // org.openjdk.jmh.runner.Action action
        24: .line 83
      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: .line 126
            aload 2 /* results */
            areturn
        end local 2 // org.openjdk.jmh.util.Multimap results
        end local 1 // org.openjdk.jmh.runner.ActionPlan actionPlan
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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 // org.openjdk.jmh.runner.BaseRunner this
        start local 1 // org.openjdk.jmh.infra.BenchmarkParams params
        start local 2 // org.openjdk.jmh.runner.ActionMode mode
        start local 3 // org.openjdk.jmh.runner.IterationResultAcceptor acceptor
         0: .line 131
            invokestatic org.openjdk.jmh.runner.BaseRunner.$SWITCH_TABLE$org$openjdk$jmh$runner$ActionMode:()[I
            aload 2 /* mode */
            invokevirtual org.openjdk.jmh.runner.ActionMode.ordinal:()I
            iaload
            tableswitch { // 2 - 4
                    2: 1
                    3: 4
                    4: 4
              default: 6
          }
         1: .line 133
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* params */
            aconst_null
            invokevirtual org.openjdk.jmh.runner.BaseRunner.runBenchmark:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
         2: .line 134
            aload 0 /* this */
            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: .line 135
            goto 18
         4: .line 139
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* params */
            aload 3 /* acceptor */
            invokevirtual org.openjdk.jmh.runner.BaseRunner.runBenchmark:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
         5: .line 140
            goto 18
         6: .line 143
      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 /* mode */
            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: .line 146
      StackMap locals:
      StackMap stack: org.openjdk.jmh.runner.BenchmarkException
            astore 4 /* be */
        start local 4 // org.openjdk.jmh.runner.BenchmarkException be
         8: .line 147
            aload 0 /* this */
            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: .line 148
            aload 0 /* this */
            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: .line 149
            aload 4 /* be */
            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 /* cause */
        start local 5 // java.lang.Throwable cause
        12: .line 150
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
            aload 5 /* cause */
            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 // java.lang.Throwable cause
        13: .line 149
            iinc 6 1
      StackMap locals:
      StackMap stack:
        14: iload 6
            iload 7
            if_icmplt 11
        15: .line 152
            aload 0 /* this */
            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: .line 154
            aload 0 /* this */
            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: .line 155
            aload 4 /* be */
            athrow
        end local 4 // org.openjdk.jmh.runner.BenchmarkException be
        18: .line 158
      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 // org.openjdk.jmh.runner.IterationResultAcceptor acceptor
        end local 2 // org.openjdk.jmh.runner.ActionMode mode
        end local 1 // org.openjdk.jmh.infra.BenchmarkParams params
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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 // org.openjdk.jmh.runner.BaseRunner this
        start local 1 // org.openjdk.jmh.infra.BenchmarkParams params
         0: .line 161
            invokestatic java.lang.System.nanoTime:()J
            lstore 2 /* current */
        start local 2 // long current
         1: .line 162
            aload 0 /* this */
            dup
            getfield org.openjdk.jmh.runner.BaseRunner.projectedRunningTime:J
            aload 0 /* this */
            aload 1 /* params */
            invokevirtual org.openjdk.jmh.runner.BaseRunner.estimateTimeSingleFork:(Lorg/openjdk/jmh/infra/BenchmarkParams;)J
            ladd
            putfield org.openjdk.jmh.runner.BaseRunner.projectedRunningTime:J
         2: .line 163
            aload 0 /* this */
            dup
            getfield org.openjdk.jmh.runner.BaseRunner.actualRunningTime:J
            lload 2 /* current */
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.benchmarkStart:J
            lsub
            ladd
            putfield org.openjdk.jmh.runner.BaseRunner.actualRunningTime:J
         3: .line 164
            aload 0 /* this */
            lload 2 /* current */
            putfield org.openjdk.jmh.runner.BaseRunner.benchmarkStart:J
         4: .line 165
            return
        end local 2 // long current
        end local 1 // org.openjdk.jmh.infra.BenchmarkParams params
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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 // org.openjdk.jmh.runner.BaseRunner this
        start local 1 // java.util.Collection plans
         0: .line 168
            aload 0 /* this */
            lconst_0
            putfield org.openjdk.jmh.runner.BaseRunner.projectedTotalTime:J
         1: .line 169
            aload 1 /* plans */
            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 /* plan */
        start local 2 // org.openjdk.jmh.runner.ActionPlan plan
         3: .line 170
            aload 2 /* plan */
            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 /* act */
        start local 4 // org.openjdk.jmh.runner.Action act
         5: .line 171
            aload 4 /* act */
            invokevirtual org.openjdk.jmh.runner.Action.getParams:()Lorg/openjdk/jmh/infra/BenchmarkParams;
            astore 6 /* params */
        start local 6 // org.openjdk.jmh.infra.BenchmarkParams params
         6: .line 172
            aload 0 /* this */
            dup
            getfield org.openjdk.jmh.runner.BaseRunner.projectedTotalTime:J
            iconst_1
            aload 6 /* params */
            invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getForks:()I
            invokestatic java.lang.Math.max:(II)I
            aload 6 /* params */
            invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getWarmupForks:()I
            iadd
            i2l
            aload 0 /* this */
            aload 6 /* params */
            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 // org.openjdk.jmh.infra.BenchmarkParams params
        end local 4 // org.openjdk.jmh.runner.Action act
         7: .line 170
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        end local 2 // org.openjdk.jmh.runner.ActionPlan plan
         8: .line 169
      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: .line 175
            return
        end local 1 // java.util.Collection plans
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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 // org.openjdk.jmh.runner.BaseRunner this
        start local 1 // org.openjdk.jmh.infra.BenchmarkParams params
         0: .line 178
            aload 1 /* params */
            invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getWarmup:()Lorg/openjdk/jmh/infra/IterationParams;
            astore 2 /* wp */
        start local 2 // org.openjdk.jmh.infra.IterationParams wp
         1: .line 179
            aload 1 /* params */
            invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getMeasurement:()Lorg/openjdk/jmh/infra/IterationParams;
            astore 3 /* mp */
        start local 3 // org.openjdk.jmh.infra.IterationParams mp
         2: .line 182
            aload 1 /* params */
            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: .line 185
            aload 2 /* wp */
            invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
            aload 3 /* mp */
            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 /* estimatedTime */
        start local 4 // long estimatedTime
         4: .line 186
            goto 9
        end local 4 // long estimatedTime
         5: .line 188
      StackMap locals: org.openjdk.jmh.infra.IterationParams org.openjdk.jmh.infra.IterationParams
      StackMap stack:
            aload 2 /* wp */
            invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
            i2l
            aload 2 /* wp */
            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: .line 189
            aload 3 /* mp */
            invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
            i2l
            aload 3 /* mp */
            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: .line 188
            ladd
         8: .line 187
            lstore 4 /* estimatedTime */
        start local 4 // long estimatedTime
         9: .line 191
      StackMap locals: long
      StackMap stack:
            lload 4 /* estimatedTime */
            lreturn
        end local 4 // long estimatedTime
        end local 3 // org.openjdk.jmh.infra.IterationParams mp
        end local 2 // org.openjdk.jmh.infra.IterationParams wp
        end local 1 // org.openjdk.jmh.infra.BenchmarkParams params
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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 // org.openjdk.jmh.runner.BaseRunner this
         0: .line 195
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.benchmarkStart:J
            lconst_0
            lcmp
            ifne 2
         1: .line 196
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            putfield org.openjdk.jmh.runner.BaseRunner.benchmarkStart:J
         2: .line 200
      StackMap locals:
      StackMap stack:
            dconst_1
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.projectedRunningTime:J
            l2d
            dmul
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.projectedTotalTime:J
            l2d
            ddiv
            dstore 3 /* partsDone */
        start local 3 // double partsDone
         3: .line 201
            dload 3 /* partsDone */
            dconst_0
            dcmpl
            ifeq 6
         4: .line 202
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.actualRunningTime:J
            l2d
            dconst_1
            dload 3 /* partsDone */
            ddiv
            dconst_1
            dsub
            dmul
            d2l
            lstore 1 /* totalETA */
        start local 1 // long totalETA
         5: .line 203
            goto 7
        end local 1 // long totalETA
         6: .line 204
      StackMap locals: org.openjdk.jmh.runner.BaseRunner top top double
      StackMap stack:
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.projectedTotalTime:J
            lstore 1 /* totalETA */
        start local 1 // long totalETA
         7: .line 207
      StackMap locals: org.openjdk.jmh.runner.BaseRunner long double
      StackMap stack:
            aload 0 /* this */
            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 /* partsDone */
            ldc 100.0
            dmul
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            dup
            iconst_1
            aload 0 /* this */
            lload 1 /* totalETA */
            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: .line 208
            return
        end local 3 // double partsDone
        end local 1 // long totalETA
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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 // org.openjdk.jmh.runner.BaseRunner this
         0: .line 211
            aload 0 /* this */
            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 /* this */
            aload 0 /* this */
            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: .line 212
            aload 0 /* this */
            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: .line 213
            return
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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 // org.openjdk.jmh.runner.BaseRunner this
        start local 1 // long nanos
         0: .line 216
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            lload 1 /* nanos */
            invokevirtual java.util.concurrent.TimeUnit.toDays:(J)J
            lstore 3 /* days */
        start local 3 // long days
         1: .line 217
            lload 1 /* nanos */
            lload 3 /* days */
            getstatic java.util.concurrent.TimeUnit.DAYS:Ljava/util/concurrent/TimeUnit;
            lconst_1
            invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
            lmul
            lsub
            lstore 1 /* nanos */
         2: .line 219
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            lload 1 /* nanos */
            invokevirtual java.util.concurrent.TimeUnit.toHours:(J)J
            lstore 5 /* hrs */
        start local 5 // long hrs
         3: .line 220
            lload 1 /* nanos */
            lload 5 /* hrs */
            getstatic java.util.concurrent.TimeUnit.HOURS:Ljava/util/concurrent/TimeUnit;
            lconst_1
            invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
            lmul
            lsub
            lstore 1 /* nanos */
         4: .line 222
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            lload 1 /* nanos */
            invokevirtual java.util.concurrent.TimeUnit.toMinutes:(J)J
            lstore 7 /* mins */
        start local 7 // long mins
         5: .line 223
            lload 1 /* nanos */
            lload 7 /* mins */
            getstatic java.util.concurrent.TimeUnit.MINUTES:Ljava/util/concurrent/TimeUnit;
            lconst_1
            invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
            lmul
            lsub
            lstore 1 /* nanos */
         6: .line 225
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            lload 1 /* nanos */
            invokevirtual java.util.concurrent.TimeUnit.toSeconds:(J)J
            lstore 9 /* secs */
        start local 9 // long secs
         7: .line 227
            ldc "%s%02d:%02d:%02d"
            iconst_4
            anewarray java.lang.Object
            dup
            iconst_0
            lload 3 /* days */
            lconst_0
            lcmp
            ifle 8
            new java.lang.StringBuilder
            dup
            lload 3 /* days */
            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 /* hrs */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_2
            lload 7 /* mins */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_3
            lload 9 /* secs */
            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 // long secs
        end local 7 // long mins
        end local 5 // long hrs
        end local 3 // long days
        end local 1 // long nanos
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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 // org.openjdk.jmh.runner.BaseRunner this
        start local 1 // org.openjdk.jmh.infra.BenchmarkParams benchParams
        start local 2 // org.openjdk.jmh.runner.IterationResultAcceptor acceptor
         0: .line 231
            aconst_null
            astore 3 /* handler */
        start local 3 // org.openjdk.jmh.runner.BenchmarkHandler handler
         1: .line 233
            new org.openjdk.jmh.runner.BenchmarkHandler
            dup
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.options:Lorg/openjdk/jmh/runner/options/Options;
            aload 1 /* benchParams */
            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 /* handler */
         2: .line 234
            aload 0 /* this */
            aload 1 /* benchParams */
            aload 3 /* handler */
            aload 2 /* acceptor */
            invokevirtual org.openjdk.jmh.runner.BaseRunner.runBenchmark:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/runner/BenchmarkHandler;Lorg/openjdk/jmh/runner/IterationResultAcceptor;)V
         3: .line 235
            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 /* be */
        start local 4 // org.openjdk.jmh.runner.BenchmarkException be
         5: .line 236
            aload 4 /* be */
            athrow
        end local 4 // org.openjdk.jmh.runner.BenchmarkException be
         6: .line 237
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 4 /* ex */
        start local 4 // java.lang.Throwable ex
         7: .line 238
            new org.openjdk.jmh.runner.BenchmarkException
            dup
            aload 4 /* ex */
            invokespecial org.openjdk.jmh.runner.BenchmarkException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.lang.Throwable ex
         8: .line 239
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 5
         9: .line 240
            aload 3 /* handler */
            ifnull 11
        10: .line 241
            aload 3 /* handler */
            invokevirtual org.openjdk.jmh.runner.BenchmarkHandler.shutdown:()V
        11: .line 243
      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: .line 240
      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 /* handler */
            ifnull 14
        13: .line 241
            aload 3 /* handler */
            invokevirtual org.openjdk.jmh.runner.BenchmarkHandler.shutdown:()V
        14: .line 244
      StackMap locals:
      StackMap stack:
            return
        end local 3 // org.openjdk.jmh.runner.BenchmarkHandler handler
        end local 2 // org.openjdk.jmh.runner.IterationResultAcceptor acceptor
        end local 1 // org.openjdk.jmh.infra.BenchmarkParams benchParams
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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 // org.openjdk.jmh.runner.BaseRunner this
        start local 1 // org.openjdk.jmh.infra.BenchmarkParams benchParams
        start local 2 // org.openjdk.jmh.runner.BenchmarkHandler handler
        start local 3 // org.openjdk.jmh.runner.IterationResultAcceptor acceptor
         0: .line 247
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 4 /* warmupTime */
        start local 4 // long warmupTime
         1: .line 249
            lconst_0
            lstore 6 /* allWarmup */
        start local 6 // long allWarmup
         2: .line 250
            lconst_0
            lstore 8 /* allMeasurement */
        start local 8 // long allMeasurement
         3: .line 253
            aload 1 /* benchParams */
            invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getWarmup:()Lorg/openjdk/jmh/infra/IterationParams;
            astore 10 /* wp */
        start local 10 // org.openjdk.jmh.infra.IterationParams wp
         4: .line 254
            iconst_1
            istore 11 /* i */
        start local 11 // int i
         5: goto 16
         6: .line 256
      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 /* this */
            invokevirtual org.openjdk.jmh.runner.BaseRunner.runSystemGC:()Z
            ifeq 8
         7: .line 257
            aload 0 /* this */
            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: .line 260
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
            aload 1 /* benchParams */
            aload 10 /* wp */
            iload 11 /* i */
            invokeinterface org.openjdk.jmh.runner.format.OutputFormat.iteration:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/infra/IterationParams;I)V
         9: .line 261
            aload 1 /* benchParams */
            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 /* isLastIteration */
        start local 12 // boolean isLastIteration
        12: .line 262
            aload 2 /* handler */
            aload 1 /* benchParams */
            aload 10 /* wp */
            iload 12 /* isLastIteration */
            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 /* ir */
        start local 13 // org.openjdk.jmh.results.IterationResult ir
        13: .line 263
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
            aload 1 /* benchParams */
            aload 10 /* wp */
            iload 11 /* i */
            aload 13 /* ir */
            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: .line 265
            lload 6 /* allWarmup */
            aload 13 /* ir */
            invokevirtual org.openjdk.jmh.results.IterationResult.getMetadata:()Lorg/openjdk/jmh/results/IterationResultMetaData;
            invokevirtual org.openjdk.jmh.results.IterationResultMetaData.getAllOps:()J
            ladd
            lstore 6 /* allWarmup */
        end local 13 // org.openjdk.jmh.results.IterationResult ir
        end local 12 // boolean isLastIteration
        15: .line 254
            iinc 11 /* i */ 1
      StackMap locals:
      StackMap stack:
        16: iload 11 /* i */
            aload 10 /* wp */
            invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
            if_icmple 6
        end local 11 // int i
        17: .line 268
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 11 /* measurementTime */
        start local 11 // long measurementTime
        18: .line 271
            aload 1 /* benchParams */
            invokevirtual org.openjdk.jmh.infra.BenchmarkParams.getMeasurement:()Lorg/openjdk/jmh/infra/IterationParams;
            astore 13 /* mp */
        start local 13 // org.openjdk.jmh.infra.IterationParams mp
        19: .line 272
            iconst_1
            istore 14 /* i */
        start local 14 // int i
        20: goto 33
        21: .line 274
      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 /* this */
            invokevirtual org.openjdk.jmh.runner.BaseRunner.runSystemGC:()Z
            ifeq 23
        22: .line 275
            aload 0 /* this */
            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: .line 279
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
            aload 1 /* benchParams */
            aload 13 /* mp */
            iload 14 /* i */
            invokeinterface org.openjdk.jmh.runner.format.OutputFormat.iteration:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/infra/IterationParams;I)V
        24: .line 281
            iload 14 /* i */
            aload 13 /* mp */
            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 /* isLastIteration */
        start local 15 // boolean isLastIteration
        27: .line 282
            aload 2 /* handler */
            aload 1 /* benchParams */
            aload 13 /* mp */
            iload 15 /* isLastIteration */
            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 /* ir */
        start local 16 // org.openjdk.jmh.results.IterationResult ir
        28: .line 283
            aload 0 /* this */
            getfield org.openjdk.jmh.runner.BaseRunner.out:Lorg/openjdk/jmh/runner/format/OutputFormat;
            aload 1 /* benchParams */
            aload 13 /* mp */
            iload 14 /* i */
            aload 16 /* ir */
            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: .line 285
            lload 8 /* allMeasurement */
            aload 16 /* ir */
            invokevirtual org.openjdk.jmh.results.IterationResult.getMetadata:()Lorg/openjdk/jmh/results/IterationResultMetaData;
            invokevirtual org.openjdk.jmh.results.IterationResultMetaData.getAllOps:()J
            ladd
            lstore 8 /* allMeasurement */
        30: .line 287
            aload 3 /* acceptor */
            ifnull 32
        31: .line 288
            aload 3 /* acceptor */
            aload 16 /* ir */
            invokeinterface org.openjdk.jmh.runner.IterationResultAcceptor.accept:(Lorg/openjdk/jmh/results/IterationResult;)V
        end local 16 // org.openjdk.jmh.results.IterationResult ir
        end local 15 // boolean isLastIteration
        32: .line 272
      StackMap locals:
      StackMap stack:
            iinc 14 /* i */ 1
      StackMap locals:
      StackMap stack:
        33: iload 14 /* i */
            aload 13 /* mp */
            invokevirtual org.openjdk.jmh.infra.IterationParams.getCount:()I
            if_icmple 21
        end local 14 // int i
        34: .line 292
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 14 /* stopTime */
        start local 14 // long stopTime
        35: .line 294
            new org.openjdk.jmh.results.BenchmarkResultMetaData
            dup
        36: .line 295
            lload 4 /* warmupTime */
            lload 11 /* measurementTime */
            lload 14 /* stopTime */
        37: .line 296
            lload 6 /* allWarmup */
            lload 8 /* allMeasurement */
        38: .line 294
            invokespecial org.openjdk.jmh.results.BenchmarkResultMetaData.<init>:(JJJJJ)V
            astore 16 /* md */
        start local 16 // org.openjdk.jmh.results.BenchmarkResultMetaData md
        39: .line 298
            aload 3 /* acceptor */
            ifnull 41
        40: .line 299
            aload 3 /* acceptor */
            aload 16 /* md */
            invokeinterface org.openjdk.jmh.runner.IterationResultAcceptor.acceptMeta:(Lorg/openjdk/jmh/results/BenchmarkResultMetaData;)V
        41: .line 301
      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 // org.openjdk.jmh.results.BenchmarkResultMetaData md
        end local 14 // long stopTime
        end local 13 // org.openjdk.jmh.infra.IterationParams mp
        end local 11 // long measurementTime
        end local 10 // org.openjdk.jmh.infra.IterationParams wp
        end local 8 // long allMeasurement
        end local 6 // long allWarmup
        end local 4 // long warmupTime
        end local 3 // org.openjdk.jmh.runner.IterationResultAcceptor acceptor
        end local 2 // org.openjdk.jmh.runner.BenchmarkHandler handler
        end local 1 // org.openjdk.jmh.infra.BenchmarkParams benchParams
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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 // org.openjdk.jmh.runner.BaseRunner this
         0: .line 309
            aload 0 /* this */
            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: .line 310
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 1 /* enabledBeans */
        start local 1 // java.util.List enabledBeans
         2: .line 312
            lconst_0
            lstore 2 /* beforeGcCount */
        start local 2 // long beforeGcCount
         3: .line 313
            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 /* bean */
        start local 4 // java.lang.management.GarbageCollectorMXBean bean
         5: .line 314
            aload 4 /* bean */
            invokeinterface java.lang.management.GarbageCollectorMXBean.getCollectionCount:()J
            lstore 6 /* count */
        start local 6 // long count
         6: .line 315
            lload 6 /* count */
            ldc -1
            lcmp
            ifeq 8
         7: .line 316
            aload 1 /* enabledBeans */
            aload 4 /* bean */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 6 // long count
        end local 4 // java.lang.management.GarbageCollectorMXBean bean
         8: .line 313
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
         9: .line 320
            aload 1 /* enabledBeans */
            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 /* bean */
        start local 4 // java.lang.management.GarbageCollectorMXBean bean
        11: .line 321
            lload 2 /* beforeGcCount */
            aload 4 /* bean */
            invokeinterface java.lang.management.GarbageCollectorMXBean.getCollectionCount:()J
            ladd
            lstore 2 /* beforeGcCount */
        end local 4 // java.lang.management.GarbageCollectorMXBean bean
        12: .line 320
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        13: .line 325
            invokestatic java.lang.System.runFinalization:()V
        14: .line 326
            invokestatic java.lang.System.gc:()V
        15: .line 327
            invokestatic java.lang.System.runFinalization:()V
        16: .line 328
            invokestatic java.lang.System.gc:()V
        17: .line 341
            aload 1 /* enabledBeans */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 24
        18: .line 342
            aload 0 /* this */
            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: .line 344
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            ldc 20000
            invokevirtual java.util.concurrent.TimeUnit.sleep:(J)V
        20: .line 345
            goto 23
      StackMap locals: org.openjdk.jmh.runner.BaseRunner java.util.List long
      StackMap stack: java.lang.InterruptedException
        21: pop
        22: .line 346
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
        23: .line 348
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        24: .line 351
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 4 /* gcHappened */
        start local 4 // boolean gcHappened
        25: .line 353
            invokestatic java.lang.System.nanoTime:()J
            lstore 5 /* start */
        start local 5 // long start
        26: .line 354
            goto 43
        27: .line 356
      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: .line 357
            goto 31
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
        29: pop
        30: .line 358
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
        31: .line 361
      StackMap locals:
      StackMap stack:
            lconst_0
            lstore 7 /* afterGcCount */
        start local 7 // long afterGcCount
        32: .line 362
            aload 1 /* enabledBeans */
            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 /* bean */
        start local 9 // java.lang.management.GarbageCollectorMXBean bean
        34: .line 363
            lload 7 /* afterGcCount */
            aload 9 /* bean */
            invokeinterface java.lang.management.GarbageCollectorMXBean.getCollectionCount:()J
            ladd
            lstore 7 /* afterGcCount */
        end local 9 // java.lang.management.GarbageCollectorMXBean bean
        35: .line 362
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 33
        36: .line 366
            iload 4 /* gcHappened */
            ifne 40
        37: .line 367
            lload 7 /* afterGcCount */
            lload 2 /* beforeGcCount */
            lsub
            ldc 2
            lcmp
            iflt 43
        38: .line 368
            iconst_1
            istore 4 /* gcHappened */
        39: .line 370
            goto 43
        40: .line 371
      StackMap locals: org.openjdk.jmh.runner.BaseRunner java.util.List long int long long
      StackMap stack:
            lload 7 /* afterGcCount */
            lload 2 /* beforeGcCount */
            lcmp
            ifne 42
        41: .line 373
            iconst_1
            ireturn
        42: .line 375
      StackMap locals:
      StackMap stack:
            lload 7 /* afterGcCount */
            lstore 2 /* beforeGcCount */
        end local 7 // long afterGcCount
        43: .line 354
      StackMap locals:
      StackMap stack:
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            invokestatic java.lang.System.nanoTime:()J
            lload 5 /* start */
            lsub
            invokevirtual java.util.concurrent.TimeUnit.toMillis:(J)J
            ldc 20000
            lcmp
            iflt 27
        44: .line 379
            iload 4 /* gcHappened */
            ifeq 47
        45: .line 380
            aload 0 /* this */
            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: .line 381
            goto 48
        47: .line 382
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            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: .line 384
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 5 // long start
        end local 4 // boolean gcHappened
        end local 2 // long beforeGcCount
        end local 1 // java.util.List enabledBeans
        49: .line 386
      StackMap locals: org.openjdk.jmh.runner.BaseRunner
      StackMap stack:
            iconst_0
            ireturn
        end local 0 // org.openjdk.jmh.runner.BaseRunner this
      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: .line 50
            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