class org.apache.cassandra.utils.ExpiringMap$1 implements java.lang.Runnable
minor version: 0
major version: 59
flags: flags: (0x0020) ACC_SUPER
this_class: org.apache.cassandra.utils.ExpiringMap$1
super_class: java.lang.Object
{
final org.apache.cassandra.utils.ExpiringMap this$0;
descriptor: Lorg/apache/cassandra/utils/ExpiringMap;
flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC
private final com.google.common.base.Function val$postExpireHook;
descriptor: Lcom/google/common/base/Function;
flags: (0x1012) ACC_PRIVATE, ACC_FINAL, ACC_SYNTHETIC
void <init>(org.apache.cassandra.utils.ExpiringMap, com.google.common.base.Function);
descriptor: (Lorg/apache/cassandra/utils/ExpiringMap;Lcom/google/common/base/Function;)V
flags: (0x0000)
Code:
stack=2, locals=3, args_size=3
start local 0 // org.apache.cassandra.utils.ExpiringMap$1 this
0: .line 84
aload 0 /* this */
aload 1
putfield org.apache.cassandra.utils.ExpiringMap$1.this$0:Lorg/apache/cassandra/utils/ExpiringMap;
aload 0 /* this */
aload 2
putfield org.apache.cassandra.utils.ExpiringMap$1.val$postExpireHook:Lcom/google/common/base/Function;
aload 0 /* this */
invokespecial java.lang.Object.<init>:()V
return
end local 0 // org.apache.cassandra.utils.ExpiringMap$1 this
LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/utils/ExpiringMap$1;
MethodParameters:
Name Flags
this$0 final
val$postExpireHook final
public void run();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=6, args_size=1
start local 0 // org.apache.cassandra.utils.ExpiringMap$1 this
0: .line 88
getstatic org.apache.cassandra.utils.Clock.instance:Lorg/apache/cassandra/utils/Clock;
invokevirtual org.apache.cassandra.utils.Clock.nanoTime:()J
lstore 1 /* start */
start local 1 // long start
1: .line 89
iconst_0
istore 3 /* n */
start local 3 // int n
2: .line 90
aload 0 /* this */
getfield org.apache.cassandra.utils.ExpiringMap$1.this$0:Lorg/apache/cassandra/utils/ExpiringMap;
getfield org.apache.cassandra.utils.ExpiringMap.cache:Ljava/util/concurrent/ConcurrentMap;
invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 5
goto 9
StackMap locals: org.apache.cassandra.utils.ExpiringMap$1 long int top java.util.Iterator
StackMap stack:
3: aload 5
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.util.Map$Entry
astore 4 /* entry */
start local 4 // java.util.Map$Entry entry
4: .line 92
aload 4 /* entry */
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast org.apache.cassandra.utils.ExpiringMap$CacheableObject
lload 1 /* start */
invokevirtual org.apache.cassandra.utils.ExpiringMap$CacheableObject.isReadyToDieAt:(J)Z
ifeq 9
5: .line 94
aload 0 /* this */
getfield org.apache.cassandra.utils.ExpiringMap$1.this$0:Lorg/apache/cassandra/utils/ExpiringMap;
getfield org.apache.cassandra.utils.ExpiringMap.cache:Ljava/util/concurrent/ConcurrentMap;
aload 4 /* entry */
invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
ifnull 9
6: .line 96
iinc 3 /* n */ 1
7: .line 97
aload 0 /* this */
getfield org.apache.cassandra.utils.ExpiringMap$1.val$postExpireHook:Lcom/google/common/base/Function;
ifnull 9
8: .line 98
aload 0 /* this */
getfield org.apache.cassandra.utils.ExpiringMap$1.val$postExpireHook:Lcom/google/common/base/Function;
aload 4 /* entry */
invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
aload 4 /* entry */
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast org.apache.cassandra.utils.ExpiringMap$CacheableObject
invokestatic org.apache.cassandra.utils.Pair.create:(Ljava/lang/Object;Ljava/lang/Object;)Lorg/apache/cassandra/utils/Pair;
invokeinterface com.google.common.base.Function.apply:(Ljava/lang/Object;)Ljava/lang/Object;
pop
end local 4 // java.util.Map$Entry entry
9: .line 90
StackMap locals:
StackMap stack:
aload 5
invokeinterface java.util.Iterator.hasNext:()Z
ifne 3
10: .line 102
getstatic org.apache.cassandra.utils.ExpiringMap.logger:Lorg/slf4j/Logger;
ldc "Expired {} entries"
iload 3 /* n */
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
11: .line 103
return
end local 3 // int n
end local 1 // long start
end local 0 // org.apache.cassandra.utils.ExpiringMap$1 this
LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lorg/apache/cassandra/utils/ExpiringMap$1;
1 12 1 start J
2 12 3 n I
4 9 4 entry Ljava/util/Map$Entry<TK;Lorg/apache/cassandra/utils/ExpiringMap$CacheableObject<TV;>;>;
}
SourceFile: "ExpiringMap.java"
EnclosingMethod: org.apache.cassandra.utils.ExpiringMap.<init>:(JLcom/google/common/base/Function;)V
NestHost: org.apache.cassandra.utils.ExpiringMap
InnerClasses:
public abstract Entry = java.util.Map$Entry of java.util.Map
org.apache.cassandra.utils.ExpiringMap$1
public CacheableObject = org.apache.cassandra.utils.ExpiringMap$CacheableObject of org.apache.cassandra.utils.ExpiringMap