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 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
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: aload 0
aload 1
putfield io.ebeaninternal.server.profile.DTimedMetricMap.name:Ljava/lang/String;
3: return
end local 1 end local 0 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 start local 1 start local 2 0: aload 0
aload 1
invokestatic java.lang.System.nanoTime:()J
lload 2
lsub
ldc 1000
ldiv
invokevirtual io.ebeaninternal.server.profile.DTimedMetricMap.add:(Ljava/lang/String;J)V
1: return
end local 2 end local 1 end local 0 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 start local 1 start local 2 0: aload 0
getfield io.ebeaninternal.server.profile.DTimedMetricMap.map:Ljava/util/concurrent/ConcurrentHashMap;
aload 1
aload 0
aload 1
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
invokevirtual io.ebeaninternal.server.profile.DTimedMetric.add:(J)V
1: return
end local 2 end local 1 end local 0 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 start local 1 0: aload 0
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
start local 2 2: aload 2
aload 1
invokevirtual io.ebeaninternal.server.profile.DTimedMetric.visit:(Lio/ebean/meta/MetricVisitor;)V
end local 2 3: StackMap locals:
StackMap stack:
aload 3
invokeinterface java.util.Iterator.hasNext:()Z
ifne 1
4: return
end local 1 end local 0 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 start local 2 0: new io.ebeaninternal.server.profile.DTimedMetric
dup
new java.lang.StringBuilder
dup
aload 0
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 end local 0 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