public class org.apache.cassandra.utils.ExpiringMap<K, V>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.utils.ExpiringMap
  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 volatile boolean shutdown;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private static final java.util.concurrent.ScheduledExecutorService service;
    descriptor: Ljava/util/concurrent/ScheduledExecutorService;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private final java.util.concurrent.ConcurrentMap<K, org.apache.cassandra.utils.ExpiringMap$CacheableObject<V>> cache;
    descriptor: Ljava/util/concurrent/ConcurrentMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentMap<TK;Lorg/apache/cassandra/utils/ExpiringMap$CacheableObject<TV;>;>;

  private final long defaultExpiration;
    descriptor: J
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 37
            ldc Lorg/apache/cassandra/utils/ExpiringMap;
            invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
            putstatic org.apache.cassandra.utils.ExpiringMap.logger:Lorg/slf4j/Logger;
         1: .line 61
            new org.apache.cassandra.concurrent.DebuggableScheduledThreadPoolExecutor
            dup
            ldc "EXPIRING-MAP-REAPER"
            invokespecial org.apache.cassandra.concurrent.DebuggableScheduledThreadPoolExecutor.<init>:(Ljava/lang/String;)V
            putstatic org.apache.cassandra.utils.ExpiringMap.service:Ljava/util/concurrent/ScheduledExecutorService;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
        start local 1 // long defaultExpiration
         0: .line 68
            aload 0 /* this */
            lload 1 /* defaultExpiration */
            aconst_null
            invokespecial org.apache.cassandra.utils.ExpiringMap.<init>:(JLcom/google/common/base/Function;)V
         1: .line 69
            return
        end local 1 // long defaultExpiration
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    2     0               this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;
            0    2     1  defaultExpiration  J
    MethodParameters:
                   Name  Flags
      defaultExpiration  

  public void <init>(long, com.google.common.base.Function<org.apache.cassandra.utils.Pair<K, org.apache.cassandra.utils.ExpiringMap$CacheableObject<V>>, ?>);
    descriptor: (JLcom/google/common/base/Function;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=5, args_size=3
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
        start local 1 // long defaultExpiration
        start local 3 // com.google.common.base.Function postExpireHook
         0: .line 75
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 63
            aload 0 /* this */
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putfield org.apache.cassandra.utils.ExpiringMap.cache:Ljava/util/concurrent/ConcurrentMap;
         2: .line 77
            aload 0 /* this */
            lload 1 /* defaultExpiration */
            putfield org.apache.cassandra.utils.ExpiringMap.defaultExpiration:J
         3: .line 79
            lload 1 /* defaultExpiration */
            lconst_0
            lcmp
            ifgt 5
         4: .line 81
            new java.lang.IllegalArgumentException
            dup
            ldc "Argument specified must be a positive number"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 84
      StackMap locals: org.apache.cassandra.utils.ExpiringMap long com.google.common.base.Function
      StackMap stack:
            new org.apache.cassandra.utils.ExpiringMap$1
            dup
            aload 0 /* this */
            aload 3 /* postExpireHook */
            invokespecial org.apache.cassandra.utils.ExpiringMap$1.<init>:(Lorg/apache/cassandra/utils/ExpiringMap;Lcom/google/common/base/Function;)V
            astore 4 /* runnable */
        start local 4 // java.lang.Runnable runnable
         6: .line 105
            getstatic org.apache.cassandra.utils.ExpiringMap.service:Ljava/util/concurrent/ScheduledExecutorService;
            aload 4 /* runnable */
            lload 1 /* defaultExpiration */
            ldc 2
            ldiv
            lload 1 /* defaultExpiration */
            ldc 2
            ldiv
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokeinterface java.util.concurrent.ScheduledExecutorService.scheduleWithFixedDelay:(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
            pop
         7: .line 106
            return
        end local 4 // java.lang.Runnable runnable
        end local 3 // com.google.common.base.Function postExpireHook
        end local 1 // long defaultExpiration
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    8     0               this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;
            0    8     1  defaultExpiration  J
            0    8     3     postExpireHook  Lcom/google/common/base/Function<Lorg/apache/cassandra/utils/Pair<TK;Lorg/apache/cassandra/utils/ExpiringMap$CacheableObject<TV;>;>;*>;
            6    8     4           runnable  Ljava/lang/Runnable;
    Signature: (JLcom/google/common/base/Function<Lorg/apache/cassandra/utils/Pair<TK;Lorg/apache/cassandra/utils/ExpiringMap$CacheableObject<TV;>;>;*>;)V
    MethodParameters:
                   Name  Flags
      defaultExpiration  
      postExpireHook     final

  public boolean shutdownBlocking();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
         0: .line 110
            getstatic org.apache.cassandra.utils.ExpiringMap.service:Ljava/util/concurrent/ScheduledExecutorService;
            invokeinterface java.util.concurrent.ScheduledExecutorService.shutdown:()V
         1: .line 113
            getstatic org.apache.cassandra.utils.ExpiringMap.service:Ljava/util/concurrent/ScheduledExecutorService;
            aload 0 /* this */
            getfield org.apache.cassandra.utils.ExpiringMap.defaultExpiration:J
            ldc 2
            lmul
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokeinterface java.util.concurrent.ScheduledExecutorService.awaitTermination:(JLjava/util/concurrent/TimeUnit;)Z
         2: ireturn
         3: .line 115
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
            astore 1 /* e */
        start local 1 // java.lang.InterruptedException e
         4: .line 117
            new java.lang.AssertionError
            dup
            aload 1 /* e */
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        end local 1 // java.lang.InterruptedException e
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;
            4    5     1     e  Ljava/lang/InterruptedException;
      Exception table:
        from    to  target  type
           1     2       3  Class java.lang.InterruptedException

  public void reset();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
         0: .line 123
            aload 0 /* this */
            iconst_0
            putfield org.apache.cassandra.utils.ExpiringMap.shutdown:Z
         1: .line 124
            aload 0 /* this */
            invokevirtual org.apache.cassandra.utils.ExpiringMap.clear:()V
         2: .line 125
            return
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;

  public void clear();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
         0: .line 129
            aload 0 /* this */
            getfield org.apache.cassandra.utils.ExpiringMap.cache:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.clear:()V
         1: .line 130
            return
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;

  public V put(K, );
    descriptor: (Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
        start local 1 // java.lang.Object key
        start local 2 // java.lang.Object value
         0: .line 134
            aload 0 /* this */
            aload 1 /* key */
            aload 2 /* value */
            aload 0 /* this */
            getfield org.apache.cassandra.utils.ExpiringMap.defaultExpiration:J
            invokevirtual org.apache.cassandra.utils.ExpiringMap.put:(Ljava/lang/Object;Ljava/lang/Object;J)Ljava/lang/Object;
            areturn
        end local 2 // java.lang.Object value
        end local 1 // java.lang.Object key
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;
            0    1     1    key  TK;
            0    1     2  value  TV;
    Signature: (TK;TV;)TV;
    MethodParameters:
       Name  Flags
      key    
      value  

  public V put(K, V, );
    descriptor: (Ljava/lang/Object;Ljava/lang/Object;J)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=6, args_size=4
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
        start local 1 // java.lang.Object key
        start local 2 // java.lang.Object value
        start local 3 // long timeout
         0: .line 139
            aload 0 /* this */
            getfield org.apache.cassandra.utils.ExpiringMap.shutdown:Z
            ifeq 2
         1: .line 145
            ldc 9223372036854775807
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            invokestatic com.google.common.util.concurrent.Uninterruptibles.sleepUninterruptibly:(JLjava/util/concurrent/TimeUnit;)V
         2: .line 147
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.utils.ExpiringMap.cache:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* key */
            new org.apache.cassandra.utils.ExpiringMap$CacheableObject
            dup
            aload 2 /* value */
            lload 3 /* timeout */
            invokespecial org.apache.cassandra.utils.ExpiringMap$CacheableObject.<init>:(Ljava/lang/Object;J)V
            invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.utils.ExpiringMap$CacheableObject
            astore 5 /* previous */
        start local 5 // org.apache.cassandra.utils.ExpiringMap$CacheableObject previous
         3: .line 148
            aload 5 /* previous */
            ifnonnull 4
            aconst_null
            goto 5
      StackMap locals: org.apache.cassandra.utils.ExpiringMap$CacheableObject
      StackMap stack:
         4: aload 5 /* previous */
            getfield org.apache.cassandra.utils.ExpiringMap$CacheableObject.value:Ljava/lang/Object;
      StackMap locals:
      StackMap stack: java.lang.Object
         5: areturn
        end local 5 // org.apache.cassandra.utils.ExpiringMap$CacheableObject previous
        end local 3 // long timeout
        end local 2 // java.lang.Object value
        end local 1 // java.lang.Object key
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;
            0    6     1       key  TK;
            0    6     2     value  TV;
            0    6     3   timeout  J
            3    6     5  previous  Lorg/apache/cassandra/utils/ExpiringMap$CacheableObject<TV;>;
    Signature: (TK;TV;J)TV;
    MethodParameters:
         Name  Flags
      key      
      value    
      timeout  

  public V get();
    descriptor: (Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
        start local 1 // java.lang.Object key
         0: .line 153
            aload 0 /* this */
            getfield org.apache.cassandra.utils.ExpiringMap.cache:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* key */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.utils.ExpiringMap$CacheableObject
            astore 2 /* co */
        start local 2 // org.apache.cassandra.utils.ExpiringMap$CacheableObject co
         1: .line 154
            aload 2 /* co */
            ifnonnull 2
            aconst_null
            goto 3
      StackMap locals: org.apache.cassandra.utils.ExpiringMap$CacheableObject
      StackMap stack:
         2: aload 2 /* co */
            getfield org.apache.cassandra.utils.ExpiringMap$CacheableObject.value:Ljava/lang/Object;
      StackMap locals:
      StackMap stack: java.lang.Object
         3: areturn
        end local 2 // org.apache.cassandra.utils.ExpiringMap$CacheableObject co
        end local 1 // java.lang.Object key
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;
            0    4     1   key  TK;
            1    4     2    co  Lorg/apache/cassandra/utils/ExpiringMap$CacheableObject<TV;>;
    Signature: (TK;)TV;
    MethodParameters:
      Name  Flags
      key   

  public V remove();
    descriptor: (Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
        start local 1 // java.lang.Object key
         0: .line 159
            aload 0 /* this */
            getfield org.apache.cassandra.utils.ExpiringMap.cache:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* key */
            invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.utils.ExpiringMap$CacheableObject
            astore 2 /* co */
        start local 2 // org.apache.cassandra.utils.ExpiringMap$CacheableObject co
         1: .line 160
            aload 2 /* co */
            ifnonnull 2
            aconst_null
            goto 3
      StackMap locals: org.apache.cassandra.utils.ExpiringMap$CacheableObject
      StackMap stack:
         2: aload 2 /* co */
            getfield org.apache.cassandra.utils.ExpiringMap$CacheableObject.value:Ljava/lang/Object;
      StackMap locals:
      StackMap stack: java.lang.Object
         3: areturn
        end local 2 // org.apache.cassandra.utils.ExpiringMap$CacheableObject co
        end local 1 // java.lang.Object key
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;
            0    4     1   key  TK;
            1    4     2    co  Lorg/apache/cassandra/utils/ExpiringMap$CacheableObject<TV;>;
    Signature: (TK;)TV;
    MethodParameters:
      Name  Flags
      key   

  public long getAge();
    descriptor: (Ljava/lang/Object;)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
        start local 1 // java.lang.Object key
         0: .line 168
            aload 0 /* this */
            getfield org.apache.cassandra.utils.ExpiringMap.cache:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* key */
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.utils.ExpiringMap$CacheableObject
            astore 2 /* co */
        start local 2 // org.apache.cassandra.utils.ExpiringMap$CacheableObject co
         1: .line 169
            aload 2 /* co */
            ifnonnull 2
            lconst_0
            goto 3
      StackMap locals: org.apache.cassandra.utils.ExpiringMap$CacheableObject
      StackMap stack:
         2: aload 2 /* co */
            getfield org.apache.cassandra.utils.ExpiringMap$CacheableObject.createdAt:J
      StackMap locals:
      StackMap stack: long
         3: lreturn
        end local 2 // org.apache.cassandra.utils.ExpiringMap$CacheableObject co
        end local 1 // java.lang.Object key
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;
            0    4     1   key  TK;
            1    4     2    co  Lorg/apache/cassandra/utils/ExpiringMap$CacheableObject<TV;>;
    Signature: (TK;)J
    MethodParameters:
      Name  Flags
      key   

  public int size();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
         0: .line 174
            aload 0 /* this */
            getfield org.apache.cassandra.utils.ExpiringMap.cache:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.size:()I
            ireturn
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;

  public boolean containsKey();
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
        start local 1 // java.lang.Object key
         0: .line 179
            aload 0 /* this */
            getfield org.apache.cassandra.utils.ExpiringMap.cache:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* key */
            invokeinterface java.util.concurrent.ConcurrentMap.containsKey:(Ljava/lang/Object;)Z
            ireturn
        end local 1 // java.lang.Object key
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;
            0    1     1   key  TK;
    Signature: (TK;)Z
    MethodParameters:
      Name  Flags
      key   

  public boolean isEmpty();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
         0: .line 184
            aload 0 /* this */
            getfield org.apache.cassandra.utils.ExpiringMap.cache:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.isEmpty:()Z
            ireturn
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;

  public java.util.Set<K> keySet();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.utils.ExpiringMap this
         0: .line 189
            aload 0 /* this */
            getfield org.apache.cassandra.utils.ExpiringMap.cache:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.keySet:()Ljava/util/Set;
            areturn
        end local 0 // org.apache.cassandra.utils.ExpiringMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/utils/ExpiringMap<TK;TV;>;
    Signature: ()Ljava/util/Set<TK;>;
}
Signature: <K:Ljava/lang/Object;V:Ljava/lang/Object;>Ljava/lang/Object;
SourceFile: "ExpiringMap.java"
NestMembers:
  org.apache.cassandra.utils.ExpiringMap$1  org.apache.cassandra.utils.ExpiringMap$CacheableObject
InnerClasses:
  org.apache.cassandra.utils.ExpiringMap$1
  public CacheableObject = org.apache.cassandra.utils.ExpiringMap$CacheableObject of org.apache.cassandra.utils.ExpiringMap