public class org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents
  super_class: java.lang.Object
{
  final java.util.Map<java.lang.String, org.openjdk.jmh.util.Multiset<java.lang.Long>> events;
    descriptor: Ljava/util/Map;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/String;Lorg/openjdk/jmh/util/Multiset<Ljava/lang/Long;>;>;

  final org.openjdk.jmh.util.IntervalMap<org.openjdk.jmh.profile.AbstractPerfAsmProfiler$MethodDesc> methods;
    descriptor: Lorg/openjdk/jmh/util/IntervalMap;
    flags: (0x0010) ACC_FINAL
    Signature: Lorg/openjdk/jmh/util/IntervalMap<Lorg/openjdk/jmh/profile/AbstractPerfAsmProfiler$MethodDesc;>;

  final java.util.Map<java.lang.String, java.lang.Long> totalCounts;
    descriptor: Ljava/util/Map;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;

  void <init>(java.util.Collection<java.lang.String>, java.util.Map<java.lang.String, org.openjdk.jmh.util.Multiset<java.lang.Long>>, org.openjdk.jmh.util.IntervalMap<org.openjdk.jmh.profile.AbstractPerfAsmProfiler$MethodDesc>);
    descriptor: (Ljava/util/Collection;Ljava/util/Map;Lorg/openjdk/jmh/util/IntervalMap;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=6, args_size=4
        start local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
        start local 1 // java.util.Collection tracedEvents
        start local 2 // java.util.Map events
        start local 3 // org.openjdk.jmh.util.IntervalMap methods
         0: .line 941
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 942
            aload 0 /* this */
            aload 2 /* events */
            putfield org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents.events:Ljava/util/Map;
         2: .line 943
            aload 0 /* this */
            aload 3 /* methods */
            putfield org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents.methods:Lorg/openjdk/jmh/util/IntervalMap;
         3: .line 944
            aload 0 /* this */
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putfield org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents.totalCounts:Ljava/util/Map;
         4: .line 945
            aload 1 /* tracedEvents */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 5
            goto 7
      StackMap locals: org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents java.util.Collection java.util.Map org.openjdk.jmh.util.IntervalMap top java.util.Iterator
      StackMap stack:
         5: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 4 /* event */
        start local 4 // java.lang.String event
         6: .line 946
            aload 0 /* this */
            getfield org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents.totalCounts:Ljava/util/Map;
            aload 4 /* event */
            aload 2 /* events */
            aload 4 /* event */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.openjdk.jmh.util.Multiset
            invokeinterface org.openjdk.jmh.util.Multiset.size:()J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 4 // java.lang.String event
         7: .line 945
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
         8: .line 948
            return
        end local 3 // org.openjdk.jmh.util.IntervalMap methods
        end local 2 // java.util.Map events
        end local 1 // java.util.Collection tracedEvents
        end local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    9     0          this  Lorg/openjdk/jmh/profile/AbstractPerfAsmProfiler$PerfEvents;
            0    9     1  tracedEvents  Ljava/util/Collection<Ljava/lang/String;>;
            0    9     2        events  Ljava/util/Map<Ljava/lang/String;Lorg/openjdk/jmh/util/Multiset<Ljava/lang/Long;>;>;
            0    9     3       methods  Lorg/openjdk/jmh/util/IntervalMap<Lorg/openjdk/jmh/profile/AbstractPerfAsmProfiler$MethodDesc;>;
            6    7     4         event  Ljava/lang/String;
    Signature: (Ljava/util/Collection<Ljava/lang/String;>;Ljava/util/Map<Ljava/lang/String;Lorg/openjdk/jmh/util/Multiset<Ljava/lang/Long;>;>;Lorg/openjdk/jmh/util/IntervalMap<Lorg/openjdk/jmh/profile/AbstractPerfAsmProfiler$MethodDesc;>;)V
    MethodParameters:
              Name  Flags
      tracedEvents  
      events        
      methods       

  public void <init>(java.util.Collection<java.lang.String>);
    descriptor: (Ljava/util/Collection;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
        start local 1 // java.util.Collection tracedEvents
         0: .line 951
            aload 0 /* this */
            aload 1 /* tracedEvents */
            invokestatic java.util.Collections.emptyMap:()Ljava/util/Map;
            new org.openjdk.jmh.util.IntervalMap
            dup
            invokespecial org.openjdk.jmh.util.IntervalMap.<init>:()V
            invokespecial org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents.<init>:(Ljava/util/Collection;Ljava/util/Map;Lorg/openjdk/jmh/util/IntervalMap;)V
         1: .line 952
            return
        end local 1 // java.util.Collection tracedEvents
        end local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    2     0          this  Lorg/openjdk/jmh/profile/AbstractPerfAsmProfiler$PerfEvents;
            0    2     1  tracedEvents  Ljava/util/Collection<Ljava/lang/String;>;
    Signature: (Ljava/util/Collection<Ljava/lang/String;>;)V
    MethodParameters:
              Name  Flags
      tracedEvents  

  public boolean isEmpty();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
         0: .line 955
            aload 0 /* this */
            getfield org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents.events:Ljava/util/Map;
            invokeinterface java.util.Map.isEmpty:()Z
            ireturn
        end local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/openjdk/jmh/profile/AbstractPerfAsmProfiler$PerfEvents;

  public org.openjdk.jmh.util.Multiset<java.lang.Long> get(java.lang.String);
    descriptor: (Ljava/lang/String;)Lorg/openjdk/jmh/util/Multiset;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
        start local 1 // java.lang.String event
         0: .line 959
            aload 0 /* this */
            getfield org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents.events:Ljava/util/Map;
            aload 1 /* event */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.openjdk.jmh.util.Multiset
            areturn
        end local 1 // java.lang.String event
        end local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lorg/openjdk/jmh/profile/AbstractPerfAsmProfiler$PerfEvents;
            0    1     1  event  Ljava/lang/String;
    Signature: (Ljava/lang/String;)Lorg/openjdk/jmh/util/Multiset<Ljava/lang/Long;>;
    MethodParameters:
       Name  Flags
      event  

  public java.util.SortedSet<java.lang.Long> getAllAddresses();
    descriptor: ()Ljava/util/SortedSet;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
         0: .line 963
            new java.util.TreeSet
            dup
            invokespecial java.util.TreeSet.<init>:()V
            astore 1 /* addrs */
        start local 1 // java.util.SortedSet addrs
         1: .line 964
            aload 0 /* this */
            getfield org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents.events:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents java.util.SortedSet top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.openjdk.jmh.util.Multiset
            astore 2 /* e */
        start local 2 // org.openjdk.jmh.util.Multiset e
         3: .line 965
            aload 1 /* addrs */
            aload 2 /* e */
            invokeinterface org.openjdk.jmh.util.Multiset.keys:()Ljava/util/Collection;
            invokeinterface java.util.SortedSet.addAll:(Ljava/util/Collection;)Z
            pop
        end local 2 // org.openjdk.jmh.util.Multiset e
         4: .line 964
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 967
            aload 1 /* addrs */
            areturn
        end local 1 // java.util.SortedSet addrs
        end local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    6     0   this  Lorg/openjdk/jmh/profile/AbstractPerfAsmProfiler$PerfEvents;
            1    6     1  addrs  Ljava/util/SortedSet<Ljava/lang/Long;>;
            3    4     2      e  Lorg/openjdk/jmh/util/Multiset<Ljava/lang/Long;>;
    Signature: ()Ljava/util/SortedSet<Ljava/lang/Long;>;

  public java.lang.Long getTotalEvents(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/Long;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
        start local 1 // java.lang.String event
         0: .line 971
            aload 0 /* this */
            getfield org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents.totalCounts:Ljava/util/Map;
            aload 1 /* event */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Long
            areturn
        end local 1 // java.lang.String event
        end local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lorg/openjdk/jmh/profile/AbstractPerfAsmProfiler$PerfEvents;
            0    1     1  event  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      event  

  public org.openjdk.jmh.profile.AbstractPerfAsmProfiler$MethodDesc getMethod(long);
    descriptor: (J)Lorg/openjdk/jmh/profile/AbstractPerfAsmProfiler$MethodDesc;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
        start local 1 // long addr
         0: .line 975
            aload 0 /* this */
            getfield org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents.methods:Lorg/openjdk/jmh/util/IntervalMap;
            lload 1 /* addr */
            invokevirtual org.openjdk.jmh.util.IntervalMap.get:(J)Ljava/lang/Object;
            checkcast org.openjdk.jmh.profile.AbstractPerfAsmProfiler$MethodDesc
            areturn
        end local 1 // long addr
        end local 0 // org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/openjdk/jmh/profile/AbstractPerfAsmProfiler$PerfEvents;
            0    1     1  addr  J
    MethodParameters:
      Name  Flags
      addr  
}
SourceFile: "AbstractPerfAsmProfiler.java"
NestHost: org.openjdk.jmh.profile.AbstractPerfAsmProfiler
InnerClasses:
  MethodDesc = org.openjdk.jmh.profile.AbstractPerfAsmProfiler$MethodDesc of org.openjdk.jmh.profile.AbstractPerfAsmProfiler
  protected PerfEvents = org.openjdk.jmh.profile.AbstractPerfAsmProfiler$PerfEvents of org.openjdk.jmh.profile.AbstractPerfAsmProfiler