public class org.openjdk.jmh.profile.HotspotThreadProfiler extends org.openjdk.jmh.profile.AbstractHotspotProfiler
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.openjdk.jmh.profile.HotspotThreadProfiler
  super_class: org.openjdk.jmh.profile.AbstractHotspotProfiler
{
  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.openjdk.jmh.profile.HotspotThreadProfiler this
         0: .line 38
            aload 0 /* this */
            ldc "HotspotThreadMBean"
            ldc "getInternalThreadingCounters"
            invokespecial org.openjdk.jmh.profile.AbstractHotspotProfiler.<init>:(Ljava/lang/String;Ljava/lang/String;)V
         1: .line 39
            return
        end local 0 // org.openjdk.jmh.profile.HotspotThreadProfiler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/openjdk/jmh/profile/HotspotThreadProfiler;
    Exceptions:
      throws org.openjdk.jmh.profile.ProfilerException

  public java.lang.String getDescription();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.openjdk.jmh.profile.HotspotThreadProfiler this
         0: .line 43
            ldc "HotSpot (tm) threading subsystem via implementation-specific MBeans"
            areturn
        end local 0 // org.openjdk.jmh.profile.HotspotThreadProfiler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/openjdk/jmh/profile/HotspotThreadProfiler;

  public java.util.Collection<? extends org.openjdk.jmh.results.Result> afterIteration(org.openjdk.jmh.infra.BenchmarkParams, org.openjdk.jmh.infra.IterationParams, org.openjdk.jmh.results.IterationResult);
    descriptor: (Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/infra/IterationParams;Lorg/openjdk/jmh/results/IterationResult;)Ljava/util/Collection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=10, locals=5, args_size=4
        start local 0 // org.openjdk.jmh.profile.HotspotThreadProfiler this
        start local 1 // org.openjdk.jmh.infra.BenchmarkParams benchmarkParams
        start local 2 // org.openjdk.jmh.infra.IterationParams iterationParams
        start local 3 // org.openjdk.jmh.results.IterationResult result
         0: .line 48
            aload 0 /* this */
            invokevirtual org.openjdk.jmh.profile.HotspotThreadProfiler.counters:()Lorg/openjdk/jmh/profile/AbstractHotspotProfiler$HotspotInternalResult;
            invokevirtual org.openjdk.jmh.profile.AbstractHotspotProfiler$HotspotInternalResult.getCurrent:()Ljava/util/Map;
            astore 4 /* current */
        start local 4 // java.util.Map current
         1: .line 49
            iconst_3
            anewarray org.openjdk.jmh.results.ScalarResult
            dup
            iconst_0
         2: .line 50
            new org.openjdk.jmh.results.ScalarResult
            dup
            ldc "\u00B7threads.alive"
         3: .line 51
            aload 4 /* current */
            ldc "java.threads.live"
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            l2d
         4: .line 52
            ldc "threads"
            getstatic org.openjdk.jmh.results.AggregationPolicy.AVG:Lorg/openjdk/jmh/results/AggregationPolicy;
         5: .line 50
            invokespecial org.openjdk.jmh.results.ScalarResult.<init>:(Ljava/lang/String;DLjava/lang/String;Lorg/openjdk/jmh/results/AggregationPolicy;)V
            aastore
            dup
            iconst_1
         6: .line 54
            new org.openjdk.jmh.results.ScalarResult
            dup
            ldc "\u00B7threads.daemon"
         7: .line 55
            aload 4 /* current */
            ldc "java.threads.daemon"
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            l2d
         8: .line 56
            ldc "threads"
            getstatic org.openjdk.jmh.results.AggregationPolicy.AVG:Lorg/openjdk/jmh/results/AggregationPolicy;
         9: .line 54
            invokespecial org.openjdk.jmh.results.ScalarResult.<init>:(Ljava/lang/String;DLjava/lang/String;Lorg/openjdk/jmh/results/AggregationPolicy;)V
            aastore
            dup
            iconst_2
        10: .line 58
            new org.openjdk.jmh.results.ScalarResult
            dup
            ldc "\u00B7threads.started"
        11: .line 59
            aload 4 /* current */
            ldc "java.threads.started"
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            l2d
        12: .line 60
            ldc "threads"
            getstatic org.openjdk.jmh.results.AggregationPolicy.MAX:Lorg/openjdk/jmh/results/AggregationPolicy;
        13: .line 58
            invokespecial org.openjdk.jmh.results.ScalarResult.<init>:(Ljava/lang/String;DLjava/lang/String;Lorg/openjdk/jmh/results/AggregationPolicy;)V
            aastore
        14: .line 49
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            areturn
        end local 4 // java.util.Map current
        end local 3 // org.openjdk.jmh.results.IterationResult result
        end local 2 // org.openjdk.jmh.infra.IterationParams iterationParams
        end local 1 // org.openjdk.jmh.infra.BenchmarkParams benchmarkParams
        end local 0 // org.openjdk.jmh.profile.HotspotThreadProfiler this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   15     0             this  Lorg/openjdk/jmh/profile/HotspotThreadProfiler;
            0   15     1  benchmarkParams  Lorg/openjdk/jmh/infra/BenchmarkParams;
            0   15     2  iterationParams  Lorg/openjdk/jmh/infra/IterationParams;
            0   15     3           result  Lorg/openjdk/jmh/results/IterationResult;
            1   15     4          current  Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;
    Signature: (Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/infra/IterationParams;Lorg/openjdk/jmh/results/IterationResult;)Ljava/util/Collection<+Lorg/openjdk/jmh/results/Result;>;
    MethodParameters:
                 Name  Flags
      benchmarkParams  
      iterationParams  
      result           

  public java.util.List getCounters();
    descriptor: ()Ljava/util/List;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokespecial org.openjdk.jmh.profile.AbstractHotspotProfiler.getCounters:()Ljava/util/List;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void beforeIteration(org.openjdk.jmh.infra.BenchmarkParams, org.openjdk.jmh.infra.IterationParams);
    descriptor: (Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/infra/IterationParams;)V
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
         0: .line 1
            aload 0
            aload 1
            aload 2
            invokespecial org.openjdk.jmh.profile.AbstractHotspotProfiler.beforeIteration:(Lorg/openjdk/jmh/infra/BenchmarkParams;Lorg/openjdk/jmh/infra/IterationParams;)V
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "HotspotThreadProfiler.java"
InnerClasses:
  HotspotInternalResult = org.openjdk.jmh.profile.AbstractHotspotProfiler$HotspotInternalResult of org.openjdk.jmh.profile.AbstractHotspotProfiler
  private HotspotCounter = org.openjdk.jmh.profile.AbstractHotspotProfiler$HotspotCounter of org.openjdk.jmh.profile.AbstractHotspotProfiler