public class org.apache.cassandra.cache.SerializingCache<K, V> implements org.apache.cassandra.cache.ICache<K, V>
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.cassandra.cache.SerializingCache
super_class: java.lang.Object
{
private static final org.slf4j.Logger logger;
descriptor: Lorg/slf4j/Logger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final int DEFAULT_CONCURENCY_LEVEL;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 64
private final com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap<K, org.apache.cassandra.cache.RefCountedMemory> map;
descriptor: Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap<TK;Lorg/apache/cassandra/cache/RefCountedMemory;>;
private final org.apache.cassandra.io.ISerializer<V> serializer;
descriptor: Lorg/apache/cassandra/io/ISerializer;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Lorg/apache/cassandra/io/ISerializer<TV;>;
static final boolean $assertionsDisabled;
descriptor: Z
flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc Lorg/apache/cassandra/cache/SerializingCache;
invokevirtual java.lang.Class.desiredAssertionStatus:()Z
ifne 1
iconst_1
goto 2
StackMap locals:
StackMap stack:
1: iconst_0
StackMap locals:
StackMap stack: int
2: putstatic org.apache.cassandra.cache.SerializingCache.$assertionsDisabled:Z
3: ldc Lorg/apache/cassandra/cache/SerializingCache;
invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
putstatic org.apache.cassandra.cache.SerializingCache.logger:Lorg/slf4j/Logger;
4: return
LocalVariableTable:
Start End Slot Name Signature
private void <init>(long, com.googlecode.concurrentlinkedhashmap.Weigher<org.apache.cassandra.cache.RefCountedMemory>, org.apache.cassandra.io.ISerializer<V>);
descriptor: (JLcom/googlecode/concurrentlinkedhashmap/Weigher;Lorg/apache/cassandra/io/ISerializer;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=6, args_size=4
start local 0 start local 1 start local 3 start local 4 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aload 4
putfield org.apache.cassandra.cache.SerializingCache.serializer:Lorg/apache/cassandra/io/ISerializer;
2: new org.apache.cassandra.cache.SerializingCache$1
dup
aload 0
invokespecial org.apache.cassandra.cache.SerializingCache$1.<init>:(Lorg/apache/cassandra/cache/SerializingCache;)V
astore 5
start local 5 3: aload 0
new com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap$Builder
dup
invokespecial com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap$Builder.<init>:()V
4: aload 3
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap$Builder.weigher:(Lcom/googlecode/concurrentlinkedhashmap/Weigher;)Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap$Builder;
5: lload 1
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap$Builder.maximumWeightedCapacity:(J)Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap$Builder;
6: bipush 64
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap$Builder.concurrencyLevel:(I)Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap$Builder;
7: aload 5
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap$Builder.listener:(Lcom/googlecode/concurrentlinkedhashmap/EvictionListener;)Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap$Builder;
8: invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap$Builder.build:()Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
9: putfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
10: return
end local 5 end local 4 end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
0 11 1 capacity J
0 11 3 weigher Lcom/googlecode/concurrentlinkedhashmap/Weigher<Lorg/apache/cassandra/cache/RefCountedMemory;>;
0 11 4 serializer Lorg/apache/cassandra/io/ISerializer<TV;>;
3 11 5 listener Lcom/googlecode/concurrentlinkedhashmap/EvictionListener<TK;Lorg/apache/cassandra/cache/RefCountedMemory;>;
Signature: (JLcom/googlecode/concurrentlinkedhashmap/Weigher<Lorg/apache/cassandra/cache/RefCountedMemory;>;Lorg/apache/cassandra/io/ISerializer<TV;>;)V
MethodParameters:
Name Flags
capacity
weigher
serializer
public static <K, V> org.apache.cassandra.cache.SerializingCache<K, V> create(long, com.googlecode.concurrentlinkedhashmap.Weigher<org.apache.cassandra.cache.RefCountedMemory>, org.apache.cassandra.io.ISerializer<V>);
descriptor: (JLcom/googlecode/concurrentlinkedhashmap/Weigher;Lorg/apache/cassandra/io/ISerializer;)Lorg/apache/cassandra/cache/SerializingCache;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=6, locals=4, args_size=3
start local 0 start local 2 start local 3 0: new org.apache.cassandra.cache.SerializingCache
dup
lload 0
aload 2
aload 3
invokespecial org.apache.cassandra.cache.SerializingCache.<init>:(JLcom/googlecode/concurrentlinkedhashmap/Weigher;Lorg/apache/cassandra/io/ISerializer;)V
areturn
end local 3 end local 2 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 weightedCapacity J
0 1 2 weigher Lcom/googlecode/concurrentlinkedhashmap/Weigher<Lorg/apache/cassandra/cache/RefCountedMemory;>;
0 1 3 serializer Lorg/apache/cassandra/io/ISerializer<TV;>;
Signature: <K:Ljava/lang/Object;V:Ljava/lang/Object;>(JLcom/googlecode/concurrentlinkedhashmap/Weigher<Lorg/apache/cassandra/cache/RefCountedMemory;>;Lorg/apache/cassandra/io/ISerializer<TV;>;)Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
MethodParameters:
Name Flags
weightedCapacity
weigher
serializer
public static <K, V> org.apache.cassandra.cache.SerializingCache<K, V> create(long, org.apache.cassandra.io.ISerializer<V>);
descriptor: (JLorg/apache/cassandra/io/ISerializer;)Lorg/apache/cassandra/cache/SerializingCache;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=4, locals=3, args_size=2
start local 0 start local 2 0: lload 0
new org.apache.cassandra.cache.SerializingCache$2
dup
invokespecial org.apache.cassandra.cache.SerializingCache$2.<init>:()V
1: aload 2
2: invokestatic org.apache.cassandra.cache.SerializingCache.create:(JLcom/googlecode/concurrentlinkedhashmap/Weigher;Lorg/apache/cassandra/io/ISerializer;)Lorg/apache/cassandra/cache/SerializingCache;
areturn
end local 2 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 weightedCapacity J
0 3 2 serializer Lorg/apache/cassandra/io/ISerializer<TV;>;
Signature: <K:Ljava/lang/Object;V:Ljava/lang/Object;>(JLorg/apache/cassandra/io/ISerializer<TV;>;)Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
MethodParameters:
Name Flags
weightedCapacity
serializer
private V deserialize(org.apache.cassandra.cache.RefCountedMemory);
descriptor: (Lorg/apache/cassandra/cache/RefCountedMemory;)Ljava/lang/Object;
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.serializer:Lorg/apache/cassandra/io/ISerializer;
new org.apache.cassandra.io.util.MemoryInputStream
dup
aload 1
invokespecial org.apache.cassandra.io.util.MemoryInputStream.<init>:(Lorg/apache/cassandra/io/util/Memory;)V
invokeinterface org.apache.cassandra.io.ISerializer.deserialize:(Lorg/apache/cassandra/io/util/DataInputPlus;)Ljava/lang/Object;
1: areturn
2: StackMap locals:
StackMap stack: java.io.IOException
astore 2
start local 2 3: getstatic org.apache.cassandra.cache.SerializingCache.logger:Lorg/slf4j/Logger;
ldc "Cannot fetch in memory data, we will fallback to read from disk "
aload 2
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Throwable;)V
4: aconst_null
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
0 5 1 mem Lorg/apache/cassandra/cache/RefCountedMemory;
3 5 2 e Ljava/io/IOException;
Exception table:
from to target type
0 1 2 Class java.io.IOException
Signature: (Lorg/apache/cassandra/cache/RefCountedMemory;)TV;
MethodParameters:
Name Flags
mem
private org.apache.cassandra.cache.RefCountedMemory serialize(V);
descriptor: (Ljava/lang/Object;)Lorg/apache/cassandra/cache/RefCountedMemory;
flags: (0x0002) ACC_PRIVATE
Code:
stack=8, locals=6, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.serializer:Lorg/apache/cassandra/io/ISerializer;
aload 1
invokeinterface org.apache.cassandra.io.ISerializer.serializedSize:(Ljava/lang/Object;)J
lstore 2
start local 2 1: lload 2
ldc 2147483647
lcmp
ifle 3
2: new java.lang.IllegalArgumentException
dup
ldc "Unable to allocate %s"
iconst_1
anewarray java.lang.Object
dup
iconst_0
lload 2
invokestatic org.apache.cassandra.utils.FBUtilities.prettyPrintMemory:(J)Ljava/lang/String;
aastore
invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals: long
StackMap stack:
new org.apache.cassandra.cache.RefCountedMemory
dup
lload 2
invokespecial org.apache.cassandra.cache.RefCountedMemory.<init>:(J)V
astore 4
start local 4 4: goto 7
end local 4 5: StackMap locals:
StackMap stack: java.lang.OutOfMemoryError
pop
6: aconst_null
areturn
start local 4 7: StackMap locals: org.apache.cassandra.cache.RefCountedMemory
StackMap stack:
aload 0
getfield org.apache.cassandra.cache.SerializingCache.serializer:Lorg/apache/cassandra/io/ISerializer;
aload 1
new org.apache.cassandra.io.util.WrappedDataOutputStreamPlus
dup
new org.apache.cassandra.io.util.MemoryOutputStream
dup
aload 4
invokespecial org.apache.cassandra.io.util.MemoryOutputStream.<init>:(Lorg/apache/cassandra/io/util/Memory;)V
invokespecial org.apache.cassandra.io.util.WrappedDataOutputStreamPlus.<init>:(Ljava/io/OutputStream;)V
invokeinterface org.apache.cassandra.io.ISerializer.serialize:(Ljava/lang/Object;Lorg/apache/cassandra/io/util/DataOutputPlus;)V
8: goto 12
9: StackMap locals:
StackMap stack: java.io.IOException
astore 5
start local 5 10: aload 4
invokevirtual org.apache.cassandra.cache.RefCountedMemory.unreference:()V
11: new java.lang.RuntimeException
dup
aload 5
invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 5 12: StackMap locals:
StackMap stack:
aload 4
areturn
end local 4 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
0 13 1 value TV;
1 13 2 serializedSize J
4 5 4 freeableMemory Lorg/apache/cassandra/cache/RefCountedMemory;
7 13 4 freeableMemory Lorg/apache/cassandra/cache/RefCountedMemory;
10 12 5 e Ljava/io/IOException;
Exception table:
from to target type
3 4 5 Class java.lang.OutOfMemoryError
7 8 9 Class java.io.IOException
Signature: (TV;)Lorg/apache/cassandra/cache/RefCountedMemory;
MethodParameters:
Name Flags
value
public long capacity();
descriptor: ()J
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.capacity:()J
lreturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
public void setCapacity(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 org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
lload 1
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.setCapacity:(J)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
0 2 1 capacity J
MethodParameters:
Name Flags
capacity
public boolean isEmpty();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.isEmpty:()Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
public int size();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.size:()I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
public long weightedSize();
descriptor: ()J
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.weightedSize:()J
lreturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
public void clear();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.clear:()V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
public V get();
descriptor: (Ljava/lang/Object;)Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=5, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
aload 1
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.apache.cassandra.cache.RefCountedMemory
astore 2
start local 2 1: aload 2
ifnonnull 3
2: aconst_null
areturn
3: StackMap locals: org.apache.cassandra.cache.RefCountedMemory
StackMap stack:
aload 2
invokevirtual org.apache.cassandra.cache.RefCountedMemory.reference:()Z
ifne 5
4: aconst_null
areturn
5: StackMap locals:
StackMap stack:
aload 0
aload 2
invokevirtual org.apache.cassandra.cache.SerializingCache.deserialize:(Lorg/apache/cassandra/cache/RefCountedMemory;)Ljava/lang/Object;
astore 4
6: aload 2
invokevirtual org.apache.cassandra.cache.RefCountedMemory.unreference:()V
7: aload 4
areturn
8: StackMap locals:
StackMap stack: java.lang.Throwable
astore 3
9: aload 2
invokevirtual org.apache.cassandra.cache.RefCountedMemory.unreference:()V
10: aload 3
athrow
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
0 11 1 key TK;
1 11 2 mem Lorg/apache/cassandra/cache/RefCountedMemory;
Exception table:
from to target type
5 6 8 any
Signature: (TK;)TV;
MethodParameters:
Name Flags
key
public void put(K, );
descriptor: (Ljava/lang/Object;Ljava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 2
invokevirtual org.apache.cassandra.cache.SerializingCache.serialize:(Ljava/lang/Object;)Lorg/apache/cassandra/cache/RefCountedMemory;
astore 3
start local 3 1: aload 3
ifnonnull 3
2: return
3: StackMap locals: org.apache.cassandra.cache.RefCountedMemory
StackMap stack:
aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
aload 1
aload 3
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.apache.cassandra.cache.RefCountedMemory
astore 4
start local 4 4: goto 8
end local 4 5: StackMap locals:
StackMap stack: java.lang.Throwable
astore 5
start local 5 6: aload 3
invokevirtual org.apache.cassandra.cache.RefCountedMemory.unreference:()V
7: aload 5
athrow
end local 5 start local 4 8: StackMap locals: org.apache.cassandra.cache.RefCountedMemory
StackMap stack:
aload 4
ifnull 10
9: aload 4
invokevirtual org.apache.cassandra.cache.RefCountedMemory.unreference:()V
10: StackMap locals:
StackMap stack:
return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
0 11 1 key TK;
0 11 2 value TV;
1 11 3 mem Lorg/apache/cassandra/cache/RefCountedMemory;
4 5 4 old Lorg/apache/cassandra/cache/RefCountedMemory;
8 11 4 old Lorg/apache/cassandra/cache/RefCountedMemory;
6 8 5 t Ljava/lang/Throwable;
Exception table:
from to target type
3 4 5 Class java.lang.Throwable
Signature: (TK;TV;)V
MethodParameters:
Name Flags
key
value
public boolean putIfAbsent(K, );
descriptor: (Ljava/lang/Object;Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 2
invokevirtual org.apache.cassandra.cache.SerializingCache.serialize:(Ljava/lang/Object;)Lorg/apache/cassandra/cache/RefCountedMemory;
astore 3
start local 3 1: aload 3
ifnonnull 3
2: iconst_0
ireturn
3: StackMap locals: org.apache.cassandra.cache.RefCountedMemory
StackMap stack:
aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
aload 1
aload 3
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.apache.cassandra.cache.RefCountedMemory
astore 4
start local 4 4: goto 8
end local 4 5: StackMap locals:
StackMap stack: java.lang.Throwable
astore 5
start local 5 6: aload 3
invokevirtual org.apache.cassandra.cache.RefCountedMemory.unreference:()V
7: aload 5
athrow
end local 5 start local 4 8: StackMap locals: org.apache.cassandra.cache.RefCountedMemory
StackMap stack:
aload 4
ifnull 10
9: aload 3
invokevirtual org.apache.cassandra.cache.RefCountedMemory.unreference:()V
10: StackMap locals:
StackMap stack:
aload 4
ifnonnull 11
iconst_1
ireturn
StackMap locals:
StackMap stack:
11: iconst_0
ireturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
0 12 1 key TK;
0 12 2 value TV;
1 12 3 mem Lorg/apache/cassandra/cache/RefCountedMemory;
4 5 4 old Lorg/apache/cassandra/cache/RefCountedMemory;
8 12 4 old Lorg/apache/cassandra/cache/RefCountedMemory;
6 8 5 t Ljava/lang/Throwable;
Exception table:
from to target type
3 4 5 Class java.lang.Throwable
Signature: (TK;TV;)Z
MethodParameters:
Name Flags
key
value
public boolean replace(K, V, );
descriptor: (Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=9, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
aload 1
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.apache.cassandra.cache.RefCountedMemory
astore 4
start local 4 1: aload 4
ifnonnull 3
2: iconst_0
ireturn
3: StackMap locals: org.apache.cassandra.cache.RefCountedMemory
StackMap stack:
aload 4
invokevirtual org.apache.cassandra.cache.RefCountedMemory.reference:()Z
ifne 5
4: iconst_0
ireturn
5: StackMap locals:
StackMap stack:
aload 0
aload 4
invokevirtual org.apache.cassandra.cache.SerializingCache.deserialize:(Lorg/apache/cassandra/cache/RefCountedMemory;)Ljava/lang/Object;
astore 5
start local 5 6: aload 4
invokevirtual org.apache.cassandra.cache.RefCountedMemory.unreference:()V
7: aload 5
aload 2
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ifne 9
8: iconst_0
ireturn
9: StackMap locals: java.lang.Object
StackMap stack:
aload 0
aload 3
invokevirtual org.apache.cassandra.cache.SerializingCache.serialize:(Ljava/lang/Object;)Lorg/apache/cassandra/cache/RefCountedMemory;
astore 6
start local 6 10: aload 6
ifnonnull 12
11: iconst_0
ireturn
12: StackMap locals: org.apache.cassandra.cache.RefCountedMemory
StackMap stack:
aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
aload 1
aload 4
aload 6
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.replace:(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
istore 7
start local 7 13: goto 17
end local 7 14: StackMap locals:
StackMap stack: java.lang.Throwable
astore 8
start local 8 15: aload 6
invokevirtual org.apache.cassandra.cache.RefCountedMemory.unreference:()V
16: aload 8
athrow
end local 8 start local 7 17: StackMap locals: int
StackMap stack:
iload 7
ifeq 19
18: aload 4
invokevirtual org.apache.cassandra.cache.RefCountedMemory.unreference:()V
goto 20
19: StackMap locals:
StackMap stack:
aload 6
invokevirtual org.apache.cassandra.cache.RefCountedMemory.unreference:()V
20: StackMap locals:
StackMap stack:
iload 7
ireturn
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 21 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
0 21 1 key TK;
0 21 2 oldToReplace TV;
0 21 3 value TV;
1 21 4 old Lorg/apache/cassandra/cache/RefCountedMemory;
6 21 5 oldValue TV;
10 21 6 mem Lorg/apache/cassandra/cache/RefCountedMemory;
13 14 7 success Z
17 21 7 success Z
15 17 8 t Ljava/lang/Throwable;
Exception table:
from to target type
12 13 14 Class java.lang.Throwable
Signature: (TK;TV;TV;)Z
MethodParameters:
Name Flags
key
oldToReplace
value
public void remove();
descriptor: (Ljava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
aload 1
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.apache.cassandra.cache.RefCountedMemory
astore 2
start local 2 1: aload 2
ifnull 3
2: aload 2
invokevirtual org.apache.cassandra.cache.RefCountedMemory.unreference:()V
3: StackMap locals: org.apache.cassandra.cache.RefCountedMemory
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
0 4 1 key TK;
1 4 2 mem Lorg/apache/cassandra/cache/RefCountedMemory;
Signature: (TK;)V
MethodParameters:
Name Flags
key
public java.util.Iterator<K> keyIterator();
descriptor: ()Ljava/util/Iterator;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.keySet:()Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
Signature: ()Ljava/util/Iterator<TK;>;
public java.util.Iterator<K> hotKeyIterator(int);
descriptor: (I)Ljava/util/Iterator;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
iload 1
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.descendingKeySetWithLimit:(I)Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
0 1 1 n I
Signature: (I)Ljava/util/Iterator<TK;>;
MethodParameters:
Name Flags
n
public boolean containsKey();
descriptor: (Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.cassandra.cache.SerializingCache.map:Lcom/googlecode/concurrentlinkedhashmap/ConcurrentLinkedHashMap;
aload 1
invokevirtual com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap.containsKey:(Ljava/lang/Object;)Z
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/cassandra/cache/SerializingCache<TK;TV;>;
0 1 1 key TK;
Signature: (TK;)Z
MethodParameters:
Name Flags
key
}
Signature: <K:Ljava/lang/Object;V:Ljava/lang/Object;>Ljava/lang/Object;Lorg/apache/cassandra/cache/ICache<TK;TV;>;
SourceFile: "SerializingCache.java"
NestMembers:
org.apache.cassandra.cache.SerializingCache$1 org.apache.cassandra.cache.SerializingCache$2
InnerClasses:
public final Builder = com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap$Builder of com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap
org.apache.cassandra.cache.SerializingCache$1
org.apache.cassandra.cache.SerializingCache$2