class io.ebeaninternal.server.profile.DTimedMetric implements io.ebean.metric.TimedMetric
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: io.ebeaninternal.server.profile.DTimedMetric
  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.atomic.LongAdder count;
    descriptor: Ljava/util/concurrent/atomic/LongAdder;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.atomic.LongAdder total;
    descriptor: Ljava/util/concurrent/atomic/LongAdder;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.atomic.LongAccumulator max;
    descriptor: Ljava/util/concurrent/atomic/LongAccumulator;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private boolean collected;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  void <init>(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=6, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.profile.DTimedMetric this
        start local 1 // java.lang.String name
         0: .line 27
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 19
            aload 0 /* this */
            new java.util.concurrent.atomic.LongAdder
            dup
            invokespecial java.util.concurrent.atomic.LongAdder.<init>:()V
            putfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
         2: .line 21
            aload 0 /* this */
            new java.util.concurrent.atomic.LongAdder
            dup
            invokespecial java.util.concurrent.atomic.LongAdder.<init>:()V
            putfield io.ebeaninternal.server.profile.DTimedMetric.total:Ljava/util/concurrent/atomic/LongAdder;
         3: .line 23
            aload 0 /* this */
            new java.util.concurrent.atomic.LongAccumulator
            dup
            invokedynamic applyAsLong()Ljava/util/function/LongBinaryOperator;
              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:
                  (JJ)J
                  java/lang/Math.max(JJ)J (6)
                  (JJ)J
            ldc -9223372036854775808
            invokespecial java.util.concurrent.atomic.LongAccumulator.<init>:(Ljava/util/function/LongBinaryOperator;J)V
            putfield io.ebeaninternal.server.profile.DTimedMetric.max:Ljava/util/concurrent/atomic/LongAccumulator;
         4: .line 28
            aload 0 /* this */
            aload 1 /* name */
            putfield io.ebeaninternal.server.profile.DTimedMetric.name:Ljava/lang/String;
         5: .line 29
            return
        end local 1 // java.lang.String name
        end local 0 // io.ebeaninternal.server.profile.DTimedMetric this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lio/ebeaninternal/server/profile/DTimedMetric;
            0    6     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  

  public void addBatchSince(long, int);
    descriptor: (JI)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=8, args_size=3
        start local 0 // io.ebeaninternal.server.profile.DTimedMetric this
        start local 1 // long startNanos
        start local 3 // int batch
         0: .line 33
            iload 3 /* batch */
            ifle 6
         1: .line 34
            invokestatic java.lang.System.nanoTime:()J
            lload 1 /* startNanos */
            lsub
            ldc 1000
            ldiv
            lstore 4 /* totalMicros */
        start local 4 // long totalMicros
         2: .line 35
            lload 4 /* totalMicros */
            iload 3 /* batch */
            i2l
            ldiv
            lstore 6 /* mean */
        start local 6 // long mean
         3: .line 36
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
            iload 3 /* batch */
            i2l
            invokevirtual java.util.concurrent.atomic.LongAdder.add:(J)V
         4: .line 37
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.total:Ljava/util/concurrent/atomic/LongAdder;
            lload 4 /* totalMicros */
            invokevirtual java.util.concurrent.atomic.LongAdder.add:(J)V
         5: .line 38
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.max:Ljava/util/concurrent/atomic/LongAccumulator;
            lload 6 /* mean */
            invokevirtual java.util.concurrent.atomic.LongAccumulator.accumulate:(J)V
        end local 6 // long mean
        end local 4 // long totalMicros
         6: .line 40
      StackMap locals:
      StackMap stack:
            return
        end local 3 // int batch
        end local 1 // long startNanos
        end local 0 // io.ebeaninternal.server.profile.DTimedMetric this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    7     0         this  Lio/ebeaninternal/server/profile/DTimedMetric;
            0    7     1   startNanos  J
            0    7     3        batch  I
            2    6     4  totalMicros  J
            3    6     6         mean  J
    MethodParameters:
            Name  Flags
      startNanos  
      batch       

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

  public void add(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // io.ebeaninternal.server.profile.DTimedMetric this
        start local 1 // long value
         0: .line 52
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
            invokevirtual java.util.concurrent.atomic.LongAdder.increment:()V
         1: .line 53
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.total:Ljava/util/concurrent/atomic/LongAdder;
            lload 1 /* value */
            invokevirtual java.util.concurrent.atomic.LongAdder.add:(J)V
         2: .line 54
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.max:Ljava/util/concurrent/atomic/LongAccumulator;
            lload 1 /* value */
            invokevirtual java.util.concurrent.atomic.LongAccumulator.accumulate:(J)V
         3: .line 55
            return
        end local 1 // long value
        end local 0 // io.ebeaninternal.server.profile.DTimedMetric this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lio/ebeaninternal/server/profile/DTimedMetric;
            0    4     1  value  J
    MethodParameters:
       Name  Flags
      value  

  public boolean isEmpty();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.profile.DTimedMetric this
         0: .line 59
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
            invokevirtual java.util.concurrent.atomic.LongAdder.sum:()J
            lconst_0
            lcmp
            ifne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // io.ebeaninternal.server.profile.DTimedMetric this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/ebeaninternal/server/profile/DTimedMetric;

  public void reset();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.profile.DTimedMetric this
         0: .line 67
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.max:Ljava/util/concurrent/atomic/LongAccumulator;
            invokevirtual java.util.concurrent.atomic.LongAccumulator.reset:()V
         1: .line 68
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
            invokevirtual java.util.concurrent.atomic.LongAdder.reset:()V
         2: .line 69
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.total:Ljava/util/concurrent/atomic/LongAdder;
            invokevirtual java.util.concurrent.atomic.LongAdder.reset:()V
         3: .line 70
            return
        end local 0 // io.ebeaninternal.server.profile.DTimedMetric this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/ebeaninternal/server/profile/DTimedMetric;

  public void visit(io.ebean.meta.MetricVisitor);
    descriptor: (Lio/ebean/meta/MetricVisitor;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // io.ebeaninternal.server.profile.DTimedMetric this
        start local 1 // io.ebean.meta.MetricVisitor visitor
         0: .line 74
            aload 0 /* this */
            aload 1 /* visitor */
            invokeinterface io.ebean.meta.MetricVisitor.isReset:()Z
            invokevirtual io.ebeaninternal.server.profile.DTimedMetric.collect:(Z)Lio/ebeaninternal/server/profile/DTimeMetricStats;
            astore 2 /* metric */
        start local 2 // io.ebeaninternal.server.profile.DTimeMetricStats metric
         1: .line 75
            aload 2 /* metric */
            ifnull 3
         2: .line 76
            aload 1 /* visitor */
            aload 2 /* metric */
            invokeinterface io.ebean.meta.MetricVisitor.visitTimed:(Lio/ebean/meta/MetaTimedMetric;)V
         3: .line 78
      StackMap locals: io.ebeaninternal.server.profile.DTimeMetricStats
      StackMap stack:
            return
        end local 2 // io.ebeaninternal.server.profile.DTimeMetricStats metric
        end local 1 // io.ebean.meta.MetricVisitor visitor
        end local 0 // io.ebeaninternal.server.profile.DTimedMetric this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    4     0     this  Lio/ebeaninternal/server/profile/DTimedMetric;
            0    4     1  visitor  Lio/ebean/meta/MetricVisitor;
            1    4     2   metric  Lio/ebeaninternal/server/profile/DTimeMetricStats;
    MethodParameters:
         Name  Flags
      visitor  

  public io.ebeaninternal.server.profile.DTimeMetricStats collect(boolean);
    descriptor: (Z)Lio/ebeaninternal/server/profile/DTimeMetricStats;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.profile.DTimedMetric this
        start local 1 // boolean reset
         0: .line 82
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
            invokevirtual java.util.concurrent.atomic.LongAdder.sum:()J
            lconst_0
            lcmp
            ifne 1
            aconst_null
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 0 /* this */
            iload 1 /* reset */
            invokevirtual io.ebeaninternal.server.profile.DTimedMetric.getStatistics:(Z)Lio/ebeaninternal/server/profile/DTimeMetricStats;
      StackMap locals:
      StackMap stack: io.ebeaninternal.server.profile.DTimeMetricStats
         2: areturn
        end local 1 // boolean reset
        end local 0 // io.ebeaninternal.server.profile.DTimedMetric this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Lio/ebeaninternal/server/profile/DTimedMetric;
            0    3     1  reset  Z
    MethodParameters:
       Name  Flags
      reset  

  private io.ebeaninternal.server.profile.DTimeMetricStats getStatistics(boolean);
    descriptor: (Z)Lio/ebeaninternal/server/profile/DTimeMetricStats;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=10, locals=4, args_size=2
        start local 0 // io.ebeaninternal.server.profile.DTimedMetric this
        start local 1 // boolean reset
         0: .line 90
            iload 1 /* reset */
            ifeq 4
         1: .line 91
            new io.ebeaninternal.server.profile.DTimeMetricStats
            dup
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.name:Ljava/lang/String;
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.collected:Z
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
            invokevirtual java.util.concurrent.atomic.LongAdder.sumThenReset:()J
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.total:Ljava/util/concurrent/atomic/LongAdder;
            invokevirtual java.util.concurrent.atomic.LongAdder.sumThenReset:()J
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.max:Ljava/util/concurrent/atomic/LongAccumulator;
            invokevirtual java.util.concurrent.atomic.LongAccumulator.getThenReset:()J
            invokespecial io.ebeaninternal.server.profile.DTimeMetricStats.<init>:(Ljava/lang/String;ZJJJ)V
            astore 3
         2: .line 96
            aload 0 /* this */
            iconst_1
            putfield io.ebeaninternal.server.profile.DTimedMetric.collected:Z
         3: .line 91
            aload 3
            areturn
         4: .line 93
      StackMap locals:
      StackMap stack:
            new io.ebeaninternal.server.profile.DTimeMetricStats
            dup
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.name:Ljava/lang/String;
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.collected:Z
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
            invokevirtual java.util.concurrent.atomic.LongAdder.sum:()J
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.total:Ljava/util/concurrent/atomic/LongAdder;
            invokevirtual java.util.concurrent.atomic.LongAdder.sum:()J
            aload 0 /* this */
            getfield io.ebeaninternal.server.profile.DTimedMetric.max:Ljava/util/concurrent/atomic/LongAccumulator;
            invokevirtual java.util.concurrent.atomic.LongAccumulator.get:()J
            invokespecial io.ebeaninternal.server.profile.DTimeMetricStats.<init>:(Ljava/lang/String;ZJJJ)V
            astore 3
         5: .line 96
            aload 0 /* this */
            iconst_1
            putfield io.ebeaninternal.server.profile.DTimedMetric.collected:Z
         6: .line 93
            aload 3
            areturn
         7: .line 95
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         8: .line 96
            aload 0 /* this */
            iconst_1
            putfield io.ebeaninternal.server.profile.DTimedMetric.collected:Z
         9: .line 97
            aload 2
            athrow
        end local 1 // boolean reset
        end local 0 // io.ebeaninternal.server.profile.DTimedMetric this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   10     0   this  Lio/ebeaninternal/server/profile/DTimedMetric;
            0   10     1  reset  Z
      Exception table:
        from    to  target  type
           0     2       7  any
           4     5       7  any
    MethodParameters:
       Name  Flags
      reset  

  public io.ebean.metric.TimedMetricStats collect(boolean);
    descriptor: (Z)Lio/ebean/metric/TimedMetricStats;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
         0: .line 1
            aload 0
            iload 1
            invokevirtual io.ebeaninternal.server.profile.DTimedMetric.collect:(Z)Lio/ebeaninternal/server/profile/DTimeMetricStats;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "DTimedMetric.java"
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles