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 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
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: aload 0
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: aload 0
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: aload 0
aload 1
putfield io.ebeaninternal.server.profile.DTimedMetric.name:Ljava/lang/String;
5: return
end local 1 end local 0 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 start local 1 start local 3 0: iload 3
ifle 6
1: invokestatic java.lang.System.nanoTime:()J
lload 1
lsub
ldc 1000
ldiv
lstore 4
start local 4 2: lload 4
iload 3
i2l
ldiv
lstore 6
start local 6 3: aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
iload 3
i2l
invokevirtual java.util.concurrent.atomic.LongAdder.add:(J)V
4: aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.total:Ljava/util/concurrent/atomic/LongAdder;
lload 4
invokevirtual java.util.concurrent.atomic.LongAdder.add:(J)V
5: aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.max:Ljava/util/concurrent/atomic/LongAccumulator;
lload 6
invokevirtual java.util.concurrent.atomic.LongAccumulator.accumulate:(J)V
end local 6 end local 4 6: StackMap locals:
StackMap stack:
return
end local 3 end local 1 end local 0 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 start local 1 0: aload 0
invokestatic java.lang.System.nanoTime:()J
lload 1
lsub
ldc 1000
ldiv
invokevirtual io.ebeaninternal.server.profile.DTimedMetric.add:(J)V
1: return
end local 1 end local 0 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 start local 1 0: aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
invokevirtual java.util.concurrent.atomic.LongAdder.increment:()V
1: aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.total:Ljava/util/concurrent/atomic/LongAdder;
lload 1
invokevirtual java.util.concurrent.atomic.LongAdder.add:(J)V
2: aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.max:Ljava/util/concurrent/atomic/LongAccumulator;
lload 1
invokevirtual java.util.concurrent.atomic.LongAccumulator.accumulate:(J)V
3: return
end local 1 end local 0 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 0: aload 0
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 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 0: aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.max:Ljava/util/concurrent/atomic/LongAccumulator;
invokevirtual java.util.concurrent.atomic.LongAccumulator.reset:()V
1: aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
invokevirtual java.util.concurrent.atomic.LongAdder.reset:()V
2: aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.total:Ljava/util/concurrent/atomic/LongAdder;
invokevirtual java.util.concurrent.atomic.LongAdder.reset:()V
3: return
end local 0 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 start local 1 0: aload 0
aload 1
invokeinterface io.ebean.meta.MetricVisitor.isReset:()Z
invokevirtual io.ebeaninternal.server.profile.DTimedMetric.collect:(Z)Lio/ebeaninternal/server/profile/DTimeMetricStats;
astore 2
start local 2 1: aload 2
ifnull 3
2: aload 1
aload 2
invokeinterface io.ebean.meta.MetricVisitor.visitTimed:(Lio/ebean/meta/MetaTimedMetric;)V
3: StackMap locals: io.ebeaninternal.server.profile.DTimeMetricStats
StackMap stack:
return
end local 2 end local 1 end local 0 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 start local 1 0: aload 0
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
iload 1
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 end local 0 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 start local 1 0: iload 1
ifeq 4
1: new io.ebeaninternal.server.profile.DTimeMetricStats
dup
aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.name:Ljava/lang/String;
aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.collected:Z
aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
invokevirtual java.util.concurrent.atomic.LongAdder.sumThenReset:()J
aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.total:Ljava/util/concurrent/atomic/LongAdder;
invokevirtual java.util.concurrent.atomic.LongAdder.sumThenReset:()J
aload 0
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: aload 0
iconst_1
putfield io.ebeaninternal.server.profile.DTimedMetric.collected:Z
3: aload 3
areturn
4: StackMap locals:
StackMap stack:
new io.ebeaninternal.server.profile.DTimeMetricStats
dup
aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.name:Ljava/lang/String;
aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.collected:Z
aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.count:Ljava/util/concurrent/atomic/LongAdder;
invokevirtual java.util.concurrent.atomic.LongAdder.sum:()J
aload 0
getfield io.ebeaninternal.server.profile.DTimedMetric.total:Ljava/util/concurrent/atomic/LongAdder;
invokevirtual java.util.concurrent.atomic.LongAdder.sum:()J
aload 0
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: aload 0
iconst_1
putfield io.ebeaninternal.server.profile.DTimedMetric.collected:Z
6: aload 3
areturn
7: StackMap locals:
StackMap stack: java.lang.Throwable
astore 2
8: aload 0
iconst_1
putfield io.ebeaninternal.server.profile.DTimedMetric.collected:Z
9: aload 2
athrow
end local 1 end local 0 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: 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