class io.ebeaninternal.server.profile.DTimedMetricMap implements io.ebean.metric.TimedMetricMap
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: io.ebeaninternal.server.profile.DTimedMetricMap
  super_class: java.lang.Object
{
  private final java.lang.String name;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.ConcurrentHashMap<java.lang.String, io.ebeaninternal.server.profile.DTimedMetric> map;
    descriptor: Ljava/util/concurrent/ConcurrentHashMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentHashMap<Ljava/lang/String;Lio/ebeaninternal/server/profile/DTimedMetric;>;

  void <init>(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.profile.DTimedMetricMap this
        start local 1 // java.lang.String name
         0: .line 14
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 12
            aload 0 /* this */
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putfield io.ebeaninternal.server.profile.DTimedMetricMap.map:Ljava/util/concurrent/ConcurrentHashMap;
         2: .line 15
            aload 0 /* this */
            aload 1 /* name */
            putfield io.ebeaninternal.server.profile.DTimedMetricMap.name:Ljava/lang/String;
         3: .line 16
            return
        end local 1 // java.lang.String name
        end local 0 // io.ebeaninternal.server.profile.DTimedMetricMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/ebeaninternal/server/profile/DTimedMetricMap;
            0    4     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  

  public void addSinceNanos(java.lang.String, long);
    descriptor: (Ljava/lang/String;J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=3
        start local 0 // io.ebeaninternal.server.profile.DTimedMetricMap this
        start local 1 // java.lang.String key
        start local 2 // long startNanos
         0: .line 20
            aload 0 /* this */
            aload 1 /* key */
            invokestatic java.lang.System.nanoTime:()J
            lload 2 /* startNanos */
            lsub
            ldc 1000
            ldiv
            invokevirtual io.ebeaninternal.server.profile.DTimedMetricMap.add:(Ljava/lang/String;J)V
         1: .line 21
            return
        end local 2 // long startNanos
        end local 1 // java.lang.String key
        end local 0 // io.ebeaninternal.server.profile.DTimedMetricMap this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lio/ebeaninternal/server/profile/DTimedMetricMap;
            0    2     1         key  Ljava/lang/String;
            0    2     2  startNanos  J
    MethodParameters:
            Name  Flags
      key         
      startNanos  

  public void add(java.lang.String, long);
    descriptor: (Ljava/lang/String;J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // io.ebeaninternal.server.profile.DTimedMetricMap this
        start local 1 // java.lang.String key
        start local 2 // long exeMicros
         0: .line 25
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetricMap.map:Ljava/util/concurrent/ConcurrentHashMap;
            aload 1 /* key */
            aload 0 /* this */
            aload 1 /* key */
            invokedynamic apply(Lio/ebeaninternal/server/profile/DTimedMetricMap;Ljava/lang/String;)Ljava/util/function/Function;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)Ljava/lang/Object;
                  io/ebeaninternal/server/profile/DTimedMetricMap.lambda$0(Ljava/lang/String;Ljava/lang/String;)Lio/ebeaninternal/server/profile/DTimedMetric; (7)
                  (Ljava/lang/String;)Lio/ebeaninternal/server/profile/DTimedMetric;
            invokevirtual java.util.concurrent.ConcurrentHashMap.computeIfAbsent:(Ljava/lang/Object;Ljava/util/function/Function;)Ljava/lang/Object;
            checkcast io.ebeaninternal.server.profile.DTimedMetric
            lload 2 /* exeMicros */
            invokevirtual io.ebeaninternal.server.profile.DTimedMetric.add:(J)V
         1: .line 26
            return
        end local 2 // long exeMicros
        end local 1 // java.lang.String key
        end local 0 // io.ebeaninternal.server.profile.DTimedMetricMap this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lio/ebeaninternal/server/profile/DTimedMetricMap;
            0    2     1        key  Ljava/lang/String;
            0    2     2  exeMicros  J
    MethodParameters:
           Name  Flags
      key        
      exeMicros  

  public void visit(io.ebean.meta.MetricVisitor);
    descriptor: (Lio/ebean/meta/MetricVisitor;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // io.ebeaninternal.server.profile.DTimedMetricMap this
        start local 1 // io.ebean.meta.MetricVisitor visitor
         0: .line 30
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetricMap.map:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 3
      StackMap locals: io.ebeaninternal.server.profile.DTimedMetricMap io.ebean.meta.MetricVisitor top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.ebeaninternal.server.profile.DTimedMetric
            astore 2 /* value */
        start local 2 // io.ebeaninternal.server.profile.DTimedMetric value
         2: .line 31
            aload 2 /* value */
            aload 1 /* visitor */
            invokevirtual io.ebeaninternal.server.profile.DTimedMetric.visit:(Lio/ebean/meta/MetricVisitor;)V
        end local 2 // io.ebeaninternal.server.profile.DTimedMetric value
         3: .line 30
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         4: .line 33
            return
        end local 1 // io.ebean.meta.MetricVisitor visitor
        end local 0 // io.ebeaninternal.server.profile.DTimedMetricMap this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Lio/ebeaninternal/server/profile/DTimedMetricMap;
            0    5     1  visitor  Lio/ebean/meta/MetricVisitor;
            2    3     2    value  Lio/ebeaninternal/server/profile/DTimedMetric;
    MethodParameters:
         Name  Flags
      visitor  

  private io.ebeaninternal.server.profile.DTimedMetric lambda$0(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)Lio/ebeaninternal/server/profile/DTimedMetric;
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // io.ebeaninternal.server.profile.DTimedMetricMap this
        start local 2 // java.lang.String k
         0: .line 25
            new io.ebeaninternal.server.profile.DTimedMetric
            dup
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetricMap.name:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial io.ebeaninternal.server.profile.DTimedMetric.<init>:(Ljava/lang/String;)V
            areturn
        end local 2 // java.lang.String k
        end local 0 // io.ebeaninternal.server.profile.DTimedMetricMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/ebeaninternal/server/profile/DTimedMetricMap;
            0    1     2     k  Ljava/lang/String;
}
SourceFile: "DTimedMetricMap.java"
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles