public class io.ebeaninternal.server.cache.DefaultServerCache implements io.ebean.cache.ServerCache
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: io.ebeaninternal.server.cache.DefaultServerCache
  super_class: java.lang.Object
{
  protected static final org.slf4j.Logger logger;
    descriptor: Lorg/slf4j/Logger;
    flags: (0x001c) ACC_PROTECTED, ACC_STATIC, ACC_FINAL

  public static final io.ebeaninternal.server.cache.DefaultServerCache$CompareByLastAccess BY_LAST_ACCESS;
    descriptor: Lio/ebeaninternal/server/cache/DefaultServerCache$CompareByLastAccess;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  protected final java.util.Map<java.lang.Object, io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry> map;
    descriptor: Ljava/util/Map;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/Object;Lio/ebeaninternal/server/cache/DefaultServerCache$CacheEntry;>;

  protected final io.ebean.metric.CountMetric hitCount;
    descriptor: Lio/ebean/metric/CountMetric;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected final io.ebean.metric.CountMetric missCount;
    descriptor: Lio/ebean/metric/CountMetric;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected final io.ebean.metric.CountMetric putCount;
    descriptor: Lio/ebean/metric/CountMetric;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected final io.ebean.metric.CountMetric removeCount;
    descriptor: Lio/ebean/metric/CountMetric;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected final io.ebean.metric.CountMetric clearCount;
    descriptor: Lio/ebean/metric/CountMetric;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected final io.ebean.metric.CountMetric evictCount;
    descriptor: Lio/ebean/metric/CountMetric;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected final java.lang.String name;
    descriptor: Ljava/lang/String;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected final java.lang.String shortName;
    descriptor: Ljava/lang/String;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  private int maxSize;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private final int trimFrequency;
    descriptor: I
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private int maxIdleSecs;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int maxSecsToLive;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private io.ebean.cache.TenantAwareKey tenantAwareKey;
    descriptor: Lio/ebean/cache/TenantAwareKey;
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 30
            ldc Lio/ebeaninternal/server/cache/DefaultServerCache;
            invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
            putstatic io.ebeaninternal.server.cache.DefaultServerCache.logger:Lorg/slf4j/Logger;
         1: .line 35
            new io.ebeaninternal.server.cache.DefaultServerCache$CompareByLastAccess
            dup
            invokespecial io.ebeaninternal.server.cache.DefaultServerCache$CompareByLastAccess.<init>:()V
            putstatic io.ebeaninternal.server.cache.DefaultServerCache.BY_LAST_ACCESS:Lio/ebeaninternal/server/cache/DefaultServerCache$CompareByLastAccess;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(io.ebeaninternal.server.cache.DefaultServerCacheConfig);
    descriptor: (Lio/ebeaninternal/server/cache/DefaultServerCacheConfig;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
        start local 1 // io.ebeaninternal.server.cache.DefaultServerCacheConfig config
         0: .line 62
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 63
            aload 0 /* this */
            aload 1 /* config */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCacheConfig.getName:()Ljava/lang/String;
            putfield io.ebeaninternal.server.cache.DefaultServerCache.name:Ljava/lang/String;
         2: .line 64
            aload 0 /* this */
            aload 1 /* config */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCacheConfig.getShortName:()Ljava/lang/String;
            putfield io.ebeaninternal.server.cache.DefaultServerCache.shortName:Ljava/lang/String;
         3: .line 65
            aload 0 /* this */
            aload 1 /* config */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCacheConfig.getMap:()Ljava/util/Map;
            putfield io.ebeaninternal.server.cache.DefaultServerCache.map:Ljava/util/Map;
         4: .line 66
            aload 0 /* this */
            aload 1 /* config */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCacheConfig.getMaxSize:()I
            putfield io.ebeaninternal.server.cache.DefaultServerCache.maxSize:I
         5: .line 67
            aload 0 /* this */
            new io.ebean.cache.TenantAwareKey
            dup
            aload 1 /* config */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCacheConfig.getTenantProvider:()Lio/ebean/config/CurrentTenantProvider;
            invokespecial io.ebean.cache.TenantAwareKey.<init>:(Lio/ebean/config/CurrentTenantProvider;)V
            putfield io.ebeaninternal.server.cache.DefaultServerCache.tenantAwareKey:Lio/ebean/cache/TenantAwareKey;
         6: .line 68
            aload 0 /* this */
            aload 1 /* config */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCacheConfig.getMaxIdleSecs:()I
            putfield io.ebeaninternal.server.cache.DefaultServerCache.maxIdleSecs:I
         7: .line 69
            aload 0 /* this */
            aload 1 /* config */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCacheConfig.getMaxSecsToLive:()I
            putfield io.ebeaninternal.server.cache.DefaultServerCache.maxSecsToLive:I
         8: .line 70
            aload 0 /* this */
            aload 1 /* config */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCacheConfig.determineTrimFrequency:()I
            putfield io.ebeaninternal.server.cache.DefaultServerCache.trimFrequency:I
         9: .line 72
            invokestatic io.ebean.metric.MetricFactory.get:()Lio/ebean/metric/MetricFactory;
            astore 2 /* factory */
        start local 2 // io.ebean.metric.MetricFactory factory
        10: .line 74
            ldc "l2n."
            astore 3 /* prefix */
        start local 3 // java.lang.String prefix
        11: .line 75
            aload 0 /* this */
            aload 2 /* factory */
            new java.lang.StringBuilder
            dup
            aload 3 /* prefix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.shortName:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ".hit"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokeinterface io.ebean.metric.MetricFactory.createCountMetric:(Ljava/lang/String;)Lio/ebean/metric/CountMetric;
            putfield io.ebeaninternal.server.cache.DefaultServerCache.hitCount:Lio/ebean/metric/CountMetric;
        12: .line 76
            aload 0 /* this */
            aload 2 /* factory */
            new java.lang.StringBuilder
            dup
            aload 3 /* prefix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.shortName:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ".miss"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokeinterface io.ebean.metric.MetricFactory.createCountMetric:(Ljava/lang/String;)Lio/ebean/metric/CountMetric;
            putfield io.ebeaninternal.server.cache.DefaultServerCache.missCount:Lio/ebean/metric/CountMetric;
        13: .line 77
            aload 0 /* this */
            aload 2 /* factory */
            new java.lang.StringBuilder
            dup
            aload 3 /* prefix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.shortName:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ".put"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokeinterface io.ebean.metric.MetricFactory.createCountMetric:(Ljava/lang/String;)Lio/ebean/metric/CountMetric;
            putfield io.ebeaninternal.server.cache.DefaultServerCache.putCount:Lio/ebean/metric/CountMetric;
        14: .line 78
            aload 0 /* this */
            aload 2 /* factory */
            new java.lang.StringBuilder
            dup
            aload 3 /* prefix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.shortName:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ".remove"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokeinterface io.ebean.metric.MetricFactory.createCountMetric:(Ljava/lang/String;)Lio/ebean/metric/CountMetric;
            putfield io.ebeaninternal.server.cache.DefaultServerCache.removeCount:Lio/ebean/metric/CountMetric;
        15: .line 79
            aload 0 /* this */
            aload 2 /* factory */
            new java.lang.StringBuilder
            dup
            aload 3 /* prefix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.shortName:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ".clear"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokeinterface io.ebean.metric.MetricFactory.createCountMetric:(Ljava/lang/String;)Lio/ebean/metric/CountMetric;
            putfield io.ebeaninternal.server.cache.DefaultServerCache.clearCount:Lio/ebean/metric/CountMetric;
        16: .line 80
            aload 0 /* this */
            aload 2 /* factory */
            new java.lang.StringBuilder
            dup
            aload 3 /* prefix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.shortName:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ".evict"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokeinterface io.ebean.metric.MetricFactory.createCountMetric:(Ljava/lang/String;)Lio/ebean/metric/CountMetric;
            putfield io.ebeaninternal.server.cache.DefaultServerCache.evictCount:Lio/ebean/metric/CountMetric;
        17: .line 81
            return
        end local 3 // java.lang.String prefix
        end local 2 // io.ebean.metric.MetricFactory factory
        end local 1 // io.ebeaninternal.server.cache.DefaultServerCacheConfig config
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   18     0     this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            0   18     1   config  Lio/ebeaninternal/server/cache/DefaultServerCacheConfig;
           10   18     2  factory  Lio/ebean/metric/MetricFactory;
           11   18     3   prefix  Ljava/lang/String;
    MethodParameters:
        Name  Flags
      config  

  public void periodicTrim(io.ebean.BackgroundExecutor);
    descriptor: (Lio/ebean/BackgroundExecutor;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=5, args_size=2
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
        start local 1 // io.ebean.BackgroundExecutor executor
         0: .line 85
            new io.ebeaninternal.server.cache.DefaultServerCache$EvictionRunnable
            dup
            aload 0 /* this */
            invokespecial io.ebeaninternal.server.cache.DefaultServerCache$EvictionRunnable.<init>:(Lio/ebeaninternal/server/cache/DefaultServerCache;)V
            astore 2 /* trim */
        start local 2 // io.ebeaninternal.server.cache.DefaultServerCache$EvictionRunnable trim
         1: .line 88
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.trimFrequency:I
            ifne 2
            bipush 60
            goto 3
      StackMap locals: io.ebeaninternal.server.cache.DefaultServerCache$EvictionRunnable
      StackMap stack:
         2: aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.trimFrequency:I
      StackMap locals:
      StackMap stack: int
         3: i2l
            lstore 3 /* trimFreqSecs */
        start local 3 // long trimFreqSecs
         4: .line 89
            aload 1 /* executor */
            aload 2 /* trim */
            lload 3 /* trimFreqSecs */
            lload 3 /* trimFreqSecs */
            getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
            invokeinterface io.ebean.BackgroundExecutor.scheduleWithFixedDelay:(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
            pop
         5: .line 90
            return
        end local 3 // long trimFreqSecs
        end local 2 // io.ebeaninternal.server.cache.DefaultServerCache$EvictionRunnable trim
        end local 1 // io.ebean.BackgroundExecutor executor
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    6     0          this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            0    6     1      executor  Lio/ebean/BackgroundExecutor;
            1    6     2          trim  Lio/ebeaninternal/server/cache/DefaultServerCache$EvictionRunnable;
            4    6     3  trimFreqSecs  J
    MethodParameters:
          Name  Flags
      executor  

  public void visit(io.ebean.meta.MetricVisitor);
    descriptor: (Lio/ebean/meta/MetricVisitor;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
        start local 1 // io.ebean.meta.MetricVisitor visitor
         0: .line 94
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.hitCount:Lio/ebean/metric/CountMetric;
            aload 1 /* visitor */
            invokeinterface io.ebean.metric.CountMetric.visit:(Lio/ebean/meta/MetricVisitor;)V
         1: .line 95
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.missCount:Lio/ebean/metric/CountMetric;
            aload 1 /* visitor */
            invokeinterface io.ebean.metric.CountMetric.visit:(Lio/ebean/meta/MetricVisitor;)V
         2: .line 96
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.putCount:Lio/ebean/metric/CountMetric;
            aload 1 /* visitor */
            invokeinterface io.ebean.metric.CountMetric.visit:(Lio/ebean/meta/MetricVisitor;)V
         3: .line 97
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.removeCount:Lio/ebean/metric/CountMetric;
            aload 1 /* visitor */
            invokeinterface io.ebean.metric.CountMetric.visit:(Lio/ebean/meta/MetricVisitor;)V
         4: .line 98
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.clearCount:Lio/ebean/metric/CountMetric;
            aload 1 /* visitor */
            invokeinterface io.ebean.metric.CountMetric.visit:(Lio/ebean/meta/MetricVisitor;)V
         5: .line 99
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.evictCount:Lio/ebean/metric/CountMetric;
            aload 1 /* visitor */
            invokeinterface io.ebean.metric.CountMetric.visit:(Lio/ebean/meta/MetricVisitor;)V
         6: .line 100
            return
        end local 1 // io.ebean.meta.MetricVisitor visitor
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            0    7     1  visitor  Lio/ebean/meta/MetricVisitor;
    MethodParameters:
         Name  Flags
      visitor  

  public io.ebean.cache.ServerCacheStatistics getStatistics(boolean);
    descriptor: (Z)Lio/ebean/cache/ServerCacheStatistics;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
        start local 1 // boolean reset
         0: .line 105
            new io.ebean.cache.ServerCacheStatistics
            dup
            invokespecial io.ebean.cache.ServerCacheStatistics.<init>:()V
            astore 2 /* cacheStats */
        start local 2 // io.ebean.cache.ServerCacheStatistics cacheStats
         1: .line 106
            aload 2 /* cacheStats */
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.name:Ljava/lang/String;
            invokevirtual io.ebean.cache.ServerCacheStatistics.setCacheName:(Ljava/lang/String;)V
         2: .line 107
            aload 2 /* cacheStats */
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.maxSize:I
            invokevirtual io.ebean.cache.ServerCacheStatistics.setMaxSize:(I)V
         3: .line 109
            aload 2 /* cacheStats */
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCache.size:()I
            invokevirtual io.ebean.cache.ServerCacheStatistics.setSize:(I)V
         4: .line 110
            aload 2 /* cacheStats */
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.hitCount:Lio/ebean/metric/CountMetric;
            iload 1 /* reset */
            invokeinterface io.ebean.metric.CountMetric.get:(Z)J
            invokevirtual io.ebean.cache.ServerCacheStatistics.setHitCount:(J)V
         5: .line 111
            aload 2 /* cacheStats */
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.missCount:Lio/ebean/metric/CountMetric;
            iload 1 /* reset */
            invokeinterface io.ebean.metric.CountMetric.get:(Z)J
            invokevirtual io.ebean.cache.ServerCacheStatistics.setMissCount:(J)V
         6: .line 112
            aload 2 /* cacheStats */
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.putCount:Lio/ebean/metric/CountMetric;
            iload 1 /* reset */
            invokeinterface io.ebean.metric.CountMetric.get:(Z)J
            invokevirtual io.ebean.cache.ServerCacheStatistics.setPutCount:(J)V
         7: .line 113
            aload 2 /* cacheStats */
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.removeCount:Lio/ebean/metric/CountMetric;
            iload 1 /* reset */
            invokeinterface io.ebean.metric.CountMetric.get:(Z)J
            invokevirtual io.ebean.cache.ServerCacheStatistics.setRemoveCount:(J)V
         8: .line 114
            aload 2 /* cacheStats */
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.clearCount:Lio/ebean/metric/CountMetric;
            iload 1 /* reset */
            invokeinterface io.ebean.metric.CountMetric.get:(Z)J
            invokevirtual io.ebean.cache.ServerCacheStatistics.setClearCount:(J)V
         9: .line 115
            aload 2 /* cacheStats */
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.evictCount:Lio/ebean/metric/CountMetric;
            iload 1 /* reset */
            invokeinterface io.ebean.metric.CountMetric.get:(Z)J
            invokevirtual io.ebean.cache.ServerCacheStatistics.setEvictCount:(J)V
        10: .line 117
            aload 2 /* cacheStats */
            areturn
        end local 2 // io.ebean.cache.ServerCacheStatistics cacheStats
        end local 1 // boolean reset
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   11     0        this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            0   11     1       reset  Z
            1   11     2  cacheStats  Lio/ebean/cache/ServerCacheStatistics;
    MethodParameters:
       Name  Flags
      reset  

  public long getHitCount();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
         0: .line 124
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.hitCount:Lio/ebean/metric/CountMetric;
            iconst_0
            invokeinterface io.ebean.metric.CountMetric.get:(Z)J
            lreturn
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/ebeaninternal/server/cache/DefaultServerCache;

  public long getMissCount();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
         0: .line 131
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.missCount:Lio/ebean/metric/CountMetric;
            iconst_0
            invokeinterface io.ebean.metric.CountMetric.get:(Z)J
            lreturn
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/ebeaninternal/server/cache/DefaultServerCache;

  public int getHitRatio();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=7, args_size=1
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
         0: .line 137
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.missCount:Lio/ebean/metric/CountMetric;
            iconst_0
            invokeinterface io.ebean.metric.CountMetric.get:(Z)J
            lstore 1 /* mc */
        start local 1 // long mc
         1: .line 138
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.hitCount:Lio/ebean/metric/CountMetric;
            iconst_0
            invokeinterface io.ebean.metric.CountMetric.get:(Z)J
            lstore 3 /* hc */
        start local 3 // long hc
         2: .line 140
            lload 3 /* hc */
            lload 1 /* mc */
            ladd
            lstore 5 /* totalCount */
        start local 5 // long totalCount
         3: .line 141
            lload 5 /* totalCount */
            lconst_0
            lcmp
            ifne 5
         4: .line 142
            iconst_0
            ireturn
         5: .line 144
      StackMap locals: long long long
      StackMap stack:
            lload 3 /* hc */
            ldc 100
            lmul
            lload 5 /* totalCount */
            ldiv
            l2i
            ireturn
        end local 5 // long totalCount
        end local 3 // long hc
        end local 1 // long mc
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    6     0        this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            1    6     1          mc  J
            2    6     3          hc  J
            3    6     5  totalCount  J

  public java.lang.String getName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
         0: .line 152
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.name:Ljava/lang/String;
            areturn
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/ebeaninternal/server/cache/DefaultServerCache;

  public java.lang.String getShortName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
         0: .line 156
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.shortName:Ljava/lang/String;
            areturn
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/ebeaninternal/server/cache/DefaultServerCache;

  public void clear();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
         0: .line 164
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.clearCount:Lio/ebean/metric/CountMetric;
            invokeinterface io.ebean.metric.CountMetric.increment:()V
         1: .line 165
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.map:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
         2: .line 166
            return
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/ebeaninternal/server/cache/DefaultServerCache;

  protected java.lang.Object key(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
        start local 1 // java.lang.Object id
         0: .line 172
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.tenantAwareKey:Lio/ebean/cache/TenantAwareKey;
            aload 1 /* id */
            invokevirtual io.ebean.cache.TenantAwareKey.key:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 1 // java.lang.Object id
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            0    1     1    id  Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      id    

  public java.lang.Object get(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
        start local 1 // java.lang.Object id
         0: .line 181
            aload 0 /* this */
            aload 1 /* id */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCache.getCacheEntry:(Ljava/lang/Object;)Lio/ebeaninternal/server/cache/DefaultServerCache$CacheEntry;
            astore 2 /* entry */
        start local 2 // io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry entry
         1: .line 182
            aload 2 /* entry */
            ifnonnull 4
         2: .line 183
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.missCount:Lio/ebean/metric/CountMetric;
            invokeinterface io.ebean.metric.CountMetric.increment:()V
         3: .line 184
            aconst_null
            areturn
         4: .line 186
      StackMap locals: io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry
      StackMap stack:
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.hitCount:Lio/ebean/metric/CountMetric;
            invokeinterface io.ebean.metric.CountMetric.increment:()V
         5: .line 187
            aload 0 /* this */
            aload 2 /* entry */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCache.unwrapEntry:(Lio/ebeaninternal/server/cache/DefaultServerCache$CacheEntry;)Ljava/lang/Object;
            areturn
        end local 2 // io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry entry
        end local 1 // java.lang.Object id
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    6     0   this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            0    6     1     id  Ljava/lang/Object;
            1    6     2  entry  Lio/ebeaninternal/server/cache/DefaultServerCache$CacheEntry;
    MethodParameters:
      Name  Flags
      id    

  protected java.lang.Object unwrapEntry(io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry);
    descriptor: (Lio/ebeaninternal/server/cache/DefaultServerCache$CacheEntry;)Ljava/lang/Object;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
        start local 1 // io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry entry
         0: .line 195
            aload 1 /* entry */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry.getValue:()Ljava/lang/Object;
            areturn
        end local 1 // io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry entry
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            0    1     1  entry  Lio/ebeaninternal/server/cache/DefaultServerCache$CacheEntry;
    MethodParameters:
       Name  Flags
      entry  

  protected io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry getCacheEntry(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Lio/ebeaninternal/server/cache/DefaultServerCache$CacheEntry;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
        start local 1 // java.lang.Object id
         0: .line 202
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.map:Ljava/util/Map;
            aload 0 /* this */
            aload 1 /* id */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCache.key:(Ljava/lang/Object;)Ljava/lang/Object;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry
            areturn
        end local 1 // java.lang.Object id
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            0    1     1    id  Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      id    

  public void putAll(java.util.Map<java.lang.Object, java.lang.Object>);
    descriptor: (Ljava/util/Map;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
        start local 1 // java.util.Map keyValues
         0: .line 207
            aload 1 /* keyValues */
            aload 0 /* this */
            invokedynamic accept(Lio/ebeaninternal/server/cache/DefaultServerCache;)Ljava/util/function/BiConsumer;
              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;)V
                  io/ebeaninternal/server/cache/DefaultServerCache.put(Ljava/lang/Object;Ljava/lang/Object;)V (5)
                  (Ljava/lang/Object;Ljava/lang/Object;)V
            invokeinterface java.util.Map.forEach:(Ljava/util/function/BiConsumer;)V
         1: .line 208
            return
        end local 1 // java.util.Map keyValues
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            0    2     1  keyValues  Ljava/util/Map<Ljava/lang/Object;Ljava/lang/Object;>;
    Signature: (Ljava/util/Map<Ljava/lang/Object;Ljava/lang/Object;>;)V
    MethodParameters:
           Name  Flags
      keyValues  

  public void put(java.lang.Object, java.lang.Object);
    descriptor: (Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=3
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
        start local 1 // java.lang.Object id
        start local 2 // java.lang.Object value
         0: .line 215
            aload 0 /* this */
            aload 1 /* id */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCache.key:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 3 /* key */
        start local 3 // java.lang.Object key
         1: .line 216
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.map:Ljava/util/Map;
            aload 3 /* key */
            new io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry
            dup
            aload 3 /* key */
            aload 2 /* value */
            invokespecial io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry.<init>:(Ljava/lang/Object;Ljava/lang/Object;)V
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 217
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.putCount:Lio/ebean/metric/CountMetric;
            invokeinterface io.ebean.metric.CountMetric.increment:()V
         3: .line 218
            return
        end local 3 // java.lang.Object key
        end local 2 // java.lang.Object value
        end local 1 // java.lang.Object id
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            0    4     1     id  Ljava/lang/Object;
            0    4     2  value  Ljava/lang/Object;
            1    4     3    key  Ljava/lang/Object;
    MethodParameters:
       Name  Flags
      id     
      value  

  public void remove(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
        start local 1 // java.lang.Object id
         0: .line 225
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.map:Ljava/util/Map;
            aload 0 /* this */
            aload 1 /* id */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCache.key:(Ljava/lang/Object;)Ljava/lang/Object;
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry
            astore 2 /* entry */
        start local 2 // io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry entry
         1: .line 226
            aload 2 /* entry */
            ifnull 3
         2: .line 227
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.removeCount:Lio/ebean/metric/CountMetric;
            invokeinterface io.ebean.metric.CountMetric.increment:()V
         3: .line 229
      StackMap locals: io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry
      StackMap stack:
            return
        end local 2 // io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry entry
        end local 1 // java.lang.Object id
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            0    4     1     id  Ljava/lang/Object;
            1    4     2  entry  Lio/ebeaninternal/server/cache/DefaultServerCache$CacheEntry;
    MethodParameters:
      Name  Flags
      id    

  public int size();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
         0: .line 236
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.map:Ljava/util/Map;
            invokeinterface java.util.Map.size:()I
            ireturn
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/ebeaninternal/server/cache/DefaultServerCache;

  protected int getTrimSize();
    descriptor: ()I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
         0: .line 246
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.maxSize:I
            bipush 90
            imul
            bipush 100
            idiv
            ireturn
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/ebeaninternal/server/cache/DefaultServerCache;

  public void runEviction();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=19, args_size=1
        start local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
         0: .line 255
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.maxSize:I
            ifne 3
         1: .line 256
            lconst_0
            lstore 1 /* trimForMaxSize */
        start local 1 // long trimForMaxSize
         2: .line 257
            goto 4
        end local 1 // long trimForMaxSize
         3: .line 258
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCache.size:()I
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.maxSize:I
            isub
            i2l
            lstore 1 /* trimForMaxSize */
        start local 1 // long trimForMaxSize
         4: .line 261
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.maxIdleSecs:I
            ifne 6
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.maxSecsToLive:I
            ifne 6
            lload 1 /* trimForMaxSize */
            lconst_0
            lcmp
            ifge 6
         5: .line 263
            return
         6: .line 266
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.nanoTime:()J
            lstore 3 /* startNanos */
        start local 3 // long startNanos
         7: .line 268
            lconst_0
            lstore 5 /* trimmedByIdle */
        start local 5 // long trimmedByIdle
         8: .line 269
            lconst_0
            lstore 7 /* trimmedByTTL */
        start local 7 // long trimmedByTTL
         9: .line 270
            lconst_0
            lstore 9 /* trimmedByLRU */
        start local 9 // long trimmedByLRU
        10: .line 272
            new java.util.ArrayList
            dup
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.map:Ljava/util/Map;
            invokeinterface java.util.Map.size:()I
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 11 /* activeList */
        start local 11 // java.util.List activeList
        11: .line 274
            lload 3 /* startNanos */
            getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.maxIdleSecs:I
            i2l
            invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
            lsub
            lstore 12 /* idleExpireNano */
        start local 12 // long idleExpireNano
        12: .line 275
            lload 3 /* startNanos */
            getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.maxSecsToLive:I
            i2l
            invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
            lsub
            lstore 14 /* ttlExpireNano */
        start local 14 // long ttlExpireNano
        13: .line 277
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.map:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 16 /* it */
        start local 16 // java.util.Iterator it
        14: .line 278
            goto 26
        15: .line 279
      StackMap locals: io.ebeaninternal.server.cache.DefaultServerCache long long long long long java.util.List long long java.util.Iterator
      StackMap stack:
            aload 16 /* it */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry
            astore 17 /* cacheEntry */
        start local 17 // io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry cacheEntry
        16: .line 280
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.maxIdleSecs:I
            ifle 20
            lload 12 /* idleExpireNano */
            aload 17 /* cacheEntry */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry.getLastAccessTime:()J
            lcmp
            ifle 20
        17: .line 281
            aload 16 /* it */
            invokeinterface java.util.Iterator.remove:()V
        18: .line 282
            lload 5 /* trimmedByIdle */
            lconst_1
            ladd
            lstore 5 /* trimmedByIdle */
        19: .line 284
            goto 26
      StackMap locals: io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry
      StackMap stack:
        20: aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.maxSecsToLive:I
            ifle 24
            lload 14 /* ttlExpireNano */
            aload 17 /* cacheEntry */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry.getCreateTime:()J
            lcmp
            ifle 24
        21: .line 285
            aload 16 /* it */
            invokeinterface java.util.Iterator.remove:()V
        22: .line 286
            lload 7 /* trimmedByTTL */
            lconst_1
            ladd
            lstore 7 /* trimmedByTTL */
        23: .line 288
            goto 26
      StackMap locals:
      StackMap stack:
        24: lload 1 /* trimForMaxSize */
            lconst_0
            lcmp
            ifle 26
        25: .line 289
            aload 11 /* activeList */
            aload 17 /* cacheEntry */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 17 // io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry cacheEntry
        26: .line 278
      StackMap locals:
      StackMap stack:
            aload 16 /* it */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 15
        27: .line 293
            lload 1 /* trimForMaxSize */
            lconst_0
            lcmp
            ifle 37
        28: .line 294
            aload 11 /* activeList */
            invokeinterface java.util.List.size:()I
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.maxSize:I
            isub
            i2l
            lstore 9 /* trimmedByLRU */
        29: .line 295
            lload 9 /* trimmedByLRU */
            lconst_0
            lcmp
            ifle 37
        30: .line 297
            aload 11 /* activeList */
            getstatic io.ebeaninternal.server.cache.DefaultServerCache.BY_LAST_ACCESS:Lio/ebeaninternal/server/cache/DefaultServerCache$CompareByLastAccess;
            invokeinterface java.util.List.sort:(Ljava/util/Comparator;)V
        31: .line 298
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCache.getTrimSize:()I
            istore 17 /* trimSize */
        start local 17 // int trimSize
        32: .line 299
            iload 17 /* trimSize */
            istore 18 /* i */
        start local 18 // int i
        33: goto 36
        34: .line 301
      StackMap locals: int int
      StackMap stack:
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.map:Ljava/util/Map;
            aload 11 /* activeList */
            iload 18 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry
            invokevirtual io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry.getKey:()Ljava/lang/Object;
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        35: .line 299
            iinc 18 /* i */ 1
      StackMap locals:
      StackMap stack:
        36: iload 18 /* i */
            aload 11 /* activeList */
            invokeinterface java.util.List.size:()I
            if_icmplt 34
        end local 18 // int i
        end local 17 // int trimSize
        37: .line 306
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.evictCount:Lio/ebean/metric/CountMetric;
            lload 5 /* trimmedByIdle */
            invokeinterface io.ebean.metric.CountMetric.add:(J)V
        38: .line 307
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.evictCount:Lio/ebean/metric/CountMetric;
            lload 7 /* trimmedByTTL */
            invokeinterface io.ebean.metric.CountMetric.add:(J)V
        39: .line 308
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.evictCount:Lio/ebean/metric/CountMetric;
            lload 9 /* trimmedByLRU */
            invokeinterface io.ebean.metric.CountMetric.add:(J)V
        40: .line 310
            getstatic io.ebeaninternal.server.cache.DefaultServerCache.logger:Lorg/slf4j/Logger;
            invokeinterface org.slf4j.Logger.isTraceEnabled:()Z
            ifeq 45
        41: .line 311
            getstatic java.util.concurrent.TimeUnit.MICROSECONDS:Ljava/util/concurrent/TimeUnit;
            invokestatic java.lang.System.nanoTime:()J
            lload 3 /* startNanos */
            lsub
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            invokevirtual java.util.concurrent.TimeUnit.convert:(JLjava/util/concurrent/TimeUnit;)J
            lstore 17 /* exeMicros */
        start local 17 // long exeMicros
        42: .line 312
            getstatic io.ebeaninternal.server.cache.DefaultServerCache.logger:Lorg/slf4j/Logger;
            ldc "Executed trim of cache {} in [{}]millis idle[{}] timeToLive[{}] accessTime[{}]"
            iconst_5
            anewarray java.lang.Object
            dup
            iconst_0
        43: .line 313
            aload 0 /* this */
            getfield io.ebeaninternal.server.cache.DefaultServerCache.name:Ljava/lang/String;
            aastore
            dup
            iconst_1
            lload 17 /* exeMicros */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_2
            lload 5 /* trimmedByIdle */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_3
            lload 7 /* trimmedByTTL */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_4
            lload 9 /* trimmedByLRU */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
        44: .line 312
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;[Ljava/lang/Object;)V
        end local 17 // long exeMicros
        45: .line 315
      StackMap locals:
      StackMap stack:
            return
        end local 16 // java.util.Iterator it
        end local 14 // long ttlExpireNano
        end local 12 // long idleExpireNano
        end local 11 // java.util.List activeList
        end local 9 // long trimmedByLRU
        end local 7 // long trimmedByTTL
        end local 5 // long trimmedByIdle
        end local 3 // long startNanos
        end local 1 // long trimForMaxSize
        end local 0 // io.ebeaninternal.server.cache.DefaultServerCache this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   46     0            this  Lio/ebeaninternal/server/cache/DefaultServerCache;
            2    3     1  trimForMaxSize  J
            4   46     1  trimForMaxSize  J
            7   46     3      startNanos  J
            8   46     5   trimmedByIdle  J
            9   46     7    trimmedByTTL  J
           10   46     9    trimmedByLRU  J
           11   46    11      activeList  Ljava/util/List<Lio/ebeaninternal/server/cache/DefaultServerCache$CacheEntry;>;
           12   46    12  idleExpireNano  J
           13   46    14   ttlExpireNano  J
           14   46    16              it  Ljava/util/Iterator<Lio/ebeaninternal/server/cache/DefaultServerCache$CacheEntry;>;
           16   26    17      cacheEntry  Lio/ebeaninternal/server/cache/DefaultServerCache$CacheEntry;
           32   37    17        trimSize  I
           33   37    18               i  I
           42   45    17       exeMicros  J
}
SourceFile: "DefaultServerCache.java"
NestMembers:
  io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry  io.ebeaninternal.server.cache.DefaultServerCache$CompareByLastAccess  io.ebeaninternal.server.cache.DefaultServerCache$EvictionRunnable
InnerClasses:
  public CacheEntry = io.ebeaninternal.server.cache.DefaultServerCache$CacheEntry of io.ebeaninternal.server.cache.DefaultServerCache
  public CompareByLastAccess = io.ebeaninternal.server.cache.DefaultServerCache$CompareByLastAccess of io.ebeaninternal.server.cache.DefaultServerCache
  public EvictionRunnable = io.ebeaninternal.server.cache.DefaultServerCache$EvictionRunnable of io.ebeaninternal.server.cache.DefaultServerCache
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles