public class io.vertx.ext.web.impl.ConcurrentLRUCache<K, V> extends java.util.concurrent.ConcurrentHashMap<K, V>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: io.vertx.ext.web.impl.ConcurrentLRUCache
  super_class: java.util.concurrent.ConcurrentHashMap
{
  private int maxSize;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private final java.util.Queue<K> queue;
    descriptor: Ljava/util/Queue;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Queue<TK;>;

  public void <init>(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // int maxSize
         0: .line 37
            aload 0 /* this */
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
         1: .line 35
            aload 0 /* this */
            new java.util.ArrayDeque
            dup
            invokespecial java.util.ArrayDeque.<init>:()V
            putfield io.vertx.ext.web.impl.ConcurrentLRUCache.queue:Ljava/util/Queue;
         2: .line 38
            aload 0 /* this */
            iload 1 /* maxSize */
            putfield io.vertx.ext.web.impl.ConcurrentLRUCache.maxSize:I
         3: .line 39
            aload 0 /* this */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.checkSize:()V
         4: .line 40
            return
        end local 1 // int maxSize
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    5     1  maxSize  I
    MethodParameters:
         Name  Flags
      maxSize  

  public void <init>(int, int);
    descriptor: (II)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // int initialCapacity
        start local 2 // int maxSize
         0: .line 43
            aload 0 /* this */
            iload 1 /* initialCapacity */
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:(I)V
         1: .line 35
            aload 0 /* this */
            new java.util.ArrayDeque
            dup
            invokespecial java.util.ArrayDeque.<init>:()V
            putfield io.vertx.ext.web.impl.ConcurrentLRUCache.queue:Ljava/util/Queue;
         2: .line 44
            aload 0 /* this */
            iload 2 /* maxSize */
            putfield io.vertx.ext.web.impl.ConcurrentLRUCache.maxSize:I
         3: .line 45
            aload 0 /* this */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.checkSize:()V
         4: .line 46
            return
        end local 2 // int maxSize
        end local 1 // int initialCapacity
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    5     0             this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    5     1  initialCapacity  I
            0    5     2          maxSize  I
    MethodParameters:
                 Name  Flags
      initialCapacity  
      maxSize          

  public void <init>(java.util.Map<? extends K, ? extends V>, );
    descriptor: (Ljava/util/Map;I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // java.util.Map m
        start local 2 // int maxSize
         0: .line 49
            aload 0 /* this */
            aload 1 /* m */
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:(Ljava/util/Map;)V
         1: .line 35
            aload 0 /* this */
            new java.util.ArrayDeque
            dup
            invokespecial java.util.ArrayDeque.<init>:()V
            putfield io.vertx.ext.web.impl.ConcurrentLRUCache.queue:Ljava/util/Queue;
         2: .line 50
            aload 0 /* this */
            iload 2 /* maxSize */
            putfield io.vertx.ext.web.impl.ConcurrentLRUCache.maxSize:I
         3: .line 51
            aload 0 /* this */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.checkSize:()V
         4: .line 52
            aload 1 /* m */
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 4
            goto 7
      StackMap locals: io.vertx.ext.web.impl.ConcurrentLRUCache java.util.Map int top java.util.Iterator
      StackMap stack:
         5: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.Object
            astore 3 /* k */
        start local 3 // java.lang.Object k
         6: .line 53
            aload 0 /* this */
            aload 3 /* k */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.entryAdded:(Ljava/lang/Object;)V
        end local 3 // java.lang.Object k
         7: .line 52
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
         8: .line 55
            aload 0 /* this */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.checkRemoveOldest:()V
         9: .line 56
            return
        end local 2 // int maxSize
        end local 1 // java.util.Map m
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   10     0     this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0   10     1        m  Ljava/util/Map<+TK;+TV;>;
            0   10     2  maxSize  I
            6    7     3        k  TK;
    Signature: (Ljava/util/Map<+TK;+TV;>;I)V
    MethodParameters:
         Name  Flags
      m        
      maxSize  

  public void <init>(int, float, int);
    descriptor: (IFI)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // int initialCapacity
        start local 2 // float loadFactor
        start local 3 // int maxSize
         0: .line 59
            aload 0 /* this */
            iload 1 /* initialCapacity */
            fload 2 /* loadFactor */
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:(IF)V
         1: .line 35
            aload 0 /* this */
            new java.util.ArrayDeque
            dup
            invokespecial java.util.ArrayDeque.<init>:()V
            putfield io.vertx.ext.web.impl.ConcurrentLRUCache.queue:Ljava/util/Queue;
         2: .line 60
            aload 0 /* this */
            iload 3 /* maxSize */
            putfield io.vertx.ext.web.impl.ConcurrentLRUCache.maxSize:I
         3: .line 61
            aload 0 /* this */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.checkSize:()V
         4: .line 62
            return
        end local 3 // int maxSize
        end local 2 // float loadFactor
        end local 1 // int initialCapacity
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    5     0             this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    5     1  initialCapacity  I
            0    5     2       loadFactor  F
            0    5     3          maxSize  I
    MethodParameters:
                 Name  Flags
      initialCapacity  
      loadFactor       
      maxSize          

  public void <init>(int, float, int, int);
    descriptor: (IFII)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=5
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // int initialCapacity
        start local 2 // float loadFactor
        start local 3 // int concurrencyLevel
        start local 4 // int maxSize
         0: .line 65
            aload 0 /* this */
            iload 1 /* initialCapacity */
            fload 2 /* loadFactor */
            iload 3 /* concurrencyLevel */
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:(IFI)V
         1: .line 35
            aload 0 /* this */
            new java.util.ArrayDeque
            dup
            invokespecial java.util.ArrayDeque.<init>:()V
            putfield io.vertx.ext.web.impl.ConcurrentLRUCache.queue:Ljava/util/Queue;
         2: .line 66
            aload 0 /* this */
            iload 4 /* maxSize */
            putfield io.vertx.ext.web.impl.ConcurrentLRUCache.maxSize:I
         3: .line 67
            aload 0 /* this */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.checkSize:()V
         4: .line 68
            return
        end local 4 // int maxSize
        end local 3 // int concurrencyLevel
        end local 2 // float loadFactor
        end local 1 // int initialCapacity
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    5     0              this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    5     1   initialCapacity  I
            0    5     2        loadFactor  F
            0    5     3  concurrencyLevel  I
            0    5     4           maxSize  I
    MethodParameters:
                  Name  Flags
      initialCapacity   
      loadFactor        
      concurrencyLevel  
      maxSize           

  public void setMaxSize(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // int maxSize
         0: .line 71
            aload 0 /* this */
            iload 1 /* maxSize */
            putfield io.vertx.ext.web.impl.ConcurrentLRUCache.maxSize:I
         1: .line 72
            aload 0 /* this */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.checkRemoveOldest:()V
         2: .line 73
            return
        end local 1 // int maxSize
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    3     1  maxSize  I
    MethodParameters:
         Name  Flags
      maxSize  

  public V put(K, );
    descriptor: (Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // java.lang.Object key
        start local 2 // java.lang.Object value
         0: .line 77
            aload 0 /* this */
            aload 1 /* key */
            aload 2 /* value */
            invokespecial java.util.concurrent.ConcurrentHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            astore 3 /* v */
        start local 3 // java.lang.Object v
         1: .line 78
            aload 3 /* v */
            ifnonnull 3
         2: .line 79
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.entryAdded:(Ljava/lang/Object;)V
         3: .line 81
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.checkRemoveOldest:()V
         4: .line 82
            aload 3 /* v */
            areturn
        end local 3 // java.lang.Object v
        end local 2 // java.lang.Object value
        end local 1 // java.lang.Object key
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    5     1    key  TK;
            0    5     2  value  TV;
            1    5     3      v  TV;
    Signature: (TK;TV;)TV;
    MethodParameters:
       Name  Flags
      key    
      value  

  public void putAll(java.util.Map<? extends K, ? extends V>);
    descriptor: (Ljava/util/Map;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // java.util.Map m
         0: .line 87
            aload 1 /* m */
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: io.vertx.ext.web.impl.ConcurrentLRUCache java.util.Map top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.Object
            astore 2 /* k */
        start local 2 // java.lang.Object k
         2: .line 88
            aload 0 /* this */
            aload 2 /* k */
            invokespecial java.util.concurrent.ConcurrentHashMap.containsKey:(Ljava/lang/Object;)Z
            ifne 4
         3: .line 89
            aload 0 /* this */
            aload 2 /* k */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.entryAdded:(Ljava/lang/Object;)V
        end local 2 // java.lang.Object k
         4: .line 87
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         5: .line 92
            aload 0 /* this */
            aload 1 /* m */
            invokespecial java.util.concurrent.ConcurrentHashMap.putAll:(Ljava/util/Map;)V
         6: .line 93
            aload 0 /* this */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.checkRemoveOldest:()V
         7: .line 94
            return
        end local 1 // java.util.Map m
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    8     1     m  Ljava/util/Map<+TK;+TV;>;
            2    4     2     k  TK;
    Signature: (Ljava/util/Map<+TK;+TV;>;)V
    MethodParameters:
      Name  Flags
      m     

  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 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // java.lang.Object key
         0: .line 98
            aload 0 /* this */
            aload 1 /* key */
            invokespecial java.util.concurrent.ConcurrentHashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* v */
        start local 2 // java.lang.Object v
         1: .line 99
            aload 2 /* v */
            ifnull 3
         2: .line 100
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.entryRemoved:(Ljava/lang/Object;)V
         3: .line 102
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 2 /* v */
            areturn
        end local 2 // java.lang.Object v
        end local 1 // java.lang.Object key
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    4     1   key  Ljava/lang/Object;
            1    4     2     v  TV;
    Signature: (Ljava/lang/Object;)TV;
    MethodParameters:
      Name  Flags
      key   

  public void clear();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
         0: .line 107
            aload 0 /* this */
            invokespecial java.util.concurrent.ConcurrentHashMap.clear:()V
         1: .line 108
            aload 0 /* this */
            getfield io.vertx.ext.web.impl.ConcurrentLRUCache.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.clear:()V
         2: .line 109
            return
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;

  public V putIfAbsent(K, );
    descriptor: (Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // java.lang.Object key
        start local 2 // java.lang.Object value
         0: .line 113
            aload 0 /* this */
            aload 1 /* key */
            aload 2 /* value */
            invokespecial java.util.concurrent.ConcurrentHashMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            astore 3 /* v */
        start local 3 // java.lang.Object v
         1: .line 114
            aload 3 /* v */
            ifnonnull 3
         2: .line 115
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.entryAdded:(Ljava/lang/Object;)V
         3: .line 117
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.checkRemoveOldest:()V
         4: .line 118
            aload 3 /* v */
            areturn
        end local 3 // java.lang.Object v
        end local 2 // java.lang.Object value
        end local 1 // java.lang.Object key
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    5     1    key  TK;
            0    5     2  value  TV;
            1    5     3      v  TV;
    Signature: (TK;TV;)TV;
    MethodParameters:
       Name  Flags
      key    
      value  

  public boolean remove(java.lang.Object, java.lang.Object);
    descriptor: (Ljava/lang/Object;Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // java.lang.Object key
        start local 2 // java.lang.Object value
         0: .line 123
            aload 0 /* this */
            aload 1 /* key */
            aload 2 /* value */
            invokespecial java.util.concurrent.ConcurrentHashMap.remove:(Ljava/lang/Object;Ljava/lang/Object;)Z
            istore 3 /* removed */
        start local 3 // boolean removed
         1: .line 124
            iload 3 /* removed */
            ifeq 3
         2: .line 125
            aload 0 /* this */
            aload 2 /* value */
            invokevirtual io.vertx.ext.web.impl.ConcurrentLRUCache.entryRemoved:(Ljava/lang/Object;)V
         3: .line 127
      StackMap locals: int
      StackMap stack:
            iload 3 /* removed */
            ireturn
        end local 3 // boolean removed
        end local 2 // java.lang.Object value
        end local 1 // java.lang.Object key
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    4     0     this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    4     1      key  Ljava/lang/Object;
            0    4     2    value  Ljava/lang/Object;
            1    4     3  removed  Z
    MethodParameters:
       Name  Flags
      key    
      value  

  public V merge(K, V, java.util.function.BiFunction<? super V, ? super V, ? extends V>);
    descriptor: (Ljava/lang/Object;Ljava/lang/Object;Ljava/util/function/BiFunction;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // java.lang.Object key
        start local 2 // java.lang.Object value
        start local 3 // java.util.function.BiFunction remappingFunction
         0: .line 132
            new java.lang.UnsupportedOperationException
            dup
            invokespecial java.lang.UnsupportedOperationException.<init>:()V
            athrow
        end local 3 // java.util.function.BiFunction remappingFunction
        end local 2 // java.lang.Object value
        end local 1 // java.lang.Object key
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    1     0               this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    1     1                key  TK;
            0    1     2              value  TV;
            0    1     3  remappingFunction  Ljava/util/function/BiFunction<-TV;-TV;+TV;>;
    Signature: (TK;TV;Ljava/util/function/BiFunction<-TV;-TV;+TV;>;)TV;
    MethodParameters:
                   Name  Flags
      key                
      value              
      remappingFunction  

  private void entryAdded();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // java.lang.Object k
         0: .line 136
            aload 0 /* this */
            getfield io.vertx.ext.web.impl.ConcurrentLRUCache.queue:Ljava/util/Queue;
            aload 1 /* k */
            invokeinterface java.util.Queue.add:(Ljava/lang/Object;)Z
            pop
         1: .line 137
            return
        end local 1 // java.lang.Object k
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    2     1     k  TK;
    Signature: (TK;)V
    MethodParameters:
      Name  Flags
      k     

  private void entryRemoved(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
        start local 1 // java.lang.Object o
         0: .line 140
            aload 0 /* this */
            getfield io.vertx.ext.web.impl.ConcurrentLRUCache.queue:Ljava/util/Queue;
            aload 1 /* o */
            invokeinterface java.util.Queue.remove:(Ljava/lang/Object;)Z
            ifne 2
         1: .line 141
            new java.lang.IllegalStateException
            dup
            ldc "Failed to remove"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 143
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Object o
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            0    3     1     o  Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      o     

  private void checkRemoveOldest();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
         0: .line 146
            goto 4
         1: .line 147
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.ext.web.impl.ConcurrentLRUCache.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
            astore 1 /* k */
        start local 1 // java.lang.Object k
         2: .line 148
            aload 1 /* k */
            ifnull 4
         3: .line 149
            aload 0 /* this */
            aload 1 /* k */
            invokespecial java.util.concurrent.ConcurrentHashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 1 // java.lang.Object k
         4: .line 146
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.ext.web.impl.ConcurrentLRUCache.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.size:()I
            aload 0 /* this */
            getfield io.vertx.ext.web.impl.ConcurrentLRUCache.maxSize:I
            if_icmpgt 1
         5: .line 152
            return
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
            2    4     1     k  TK;

  private void checkSize();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
         0: .line 155
            aload 0 /* this */
            getfield io.vertx.ext.web.impl.ConcurrentLRUCache.maxSize:I
            iconst_1
            if_icmpge 2
         1: .line 156
            new java.lang.IllegalArgumentException
            dup
            ldc "maxSize must be >= 1"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 158
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;

  public int queueSize();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
         0: .line 161
            aload 0 /* this */
            getfield io.vertx.ext.web.impl.ConcurrentLRUCache.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.size:()I
            ireturn
        end local 0 // io.vertx.ext.web.impl.ConcurrentLRUCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/vertx/ext/web/impl/ConcurrentLRUCache<TK;TV;>;
}
Signature: <K:Ljava/lang/Object;V:Ljava/lang/Object;>Ljava/util/concurrent/ConcurrentHashMap<TK;TV;>;
SourceFile: "ConcurrentLRUCache.java"