public class com.netflix.hystrix.HystrixThreadPoolMetrics extends com.netflix.hystrix.HystrixMetrics
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: com.netflix.hystrix.HystrixThreadPoolMetrics
  super_class: com.netflix.hystrix.HystrixMetrics
{
  private static final com.netflix.hystrix.HystrixEventType[] ALL_COMMAND_EVENT_TYPES;
    descriptor: [Lcom/netflix/hystrix/HystrixEventType;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final com.netflix.hystrix.HystrixEventType$ThreadPool[] ALL_THREADPOOL_EVENT_TYPES;
    descriptor: [Lcom/netflix/hystrix/HystrixEventType$ThreadPool;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int NUMBER_THREADPOOL_EVENT_TYPES;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.util.concurrent.ConcurrentHashMap<java.lang.String, com.netflix.hystrix.HystrixThreadPoolMetrics> metrics;
    descriptor: Ljava/util/concurrent/ConcurrentHashMap;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentHashMap<Ljava/lang/String;Lcom/netflix/hystrix/HystrixThreadPoolMetrics;>;

  public static final rx.functions.Func2<long[], com.netflix.hystrix.metric.HystrixCommandCompletion, long[]> appendEventToBucket;
    descriptor: Lrx/functions/Func2;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    Signature: Lrx/functions/Func2<[JLcom/netflix/hystrix/metric/HystrixCommandCompletion;[J>;

  public static final rx.functions.Func2<long[], long[], long[]> counterAggregator;
    descriptor: Lrx/functions/Func2;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    Signature: Lrx/functions/Func2<[J[J[J>;

  private final com.netflix.hystrix.HystrixThreadPoolKey threadPoolKey;
    descriptor: Lcom/netflix/hystrix/HystrixThreadPoolKey;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.ThreadPoolExecutor threadPool;
    descriptor: Ljava/util/concurrent/ThreadPoolExecutor;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final com.netflix.hystrix.HystrixThreadPoolProperties properties;
    descriptor: Lcom/netflix/hystrix/HystrixThreadPoolProperties;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.atomic.AtomicInteger concurrentExecutionCount;
    descriptor: Ljava/util/concurrent/atomic/AtomicInteger;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final com.netflix.hystrix.metric.consumer.RollingThreadPoolEventCounterStream rollingCounterStream;
    descriptor: Lcom/netflix/hystrix/metric/consumer/RollingThreadPoolEventCounterStream;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final com.netflix.hystrix.metric.consumer.CumulativeThreadPoolEventCounterStream cumulativeCounterStream;
    descriptor: Lcom/netflix/hystrix/metric/consumer/CumulativeThreadPoolEventCounterStream;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final com.netflix.hystrix.metric.consumer.RollingThreadPoolMaxConcurrencyStream rollingThreadPoolMaxConcurrencyStream;
    descriptor: Lcom/netflix/hystrix/metric/consumer/RollingThreadPoolMaxConcurrencyStream;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 42
            invokestatic com.netflix.hystrix.HystrixEventType.values:()[Lcom/netflix/hystrix/HystrixEventType;
            putstatic com.netflix.hystrix.HystrixThreadPoolMetrics.ALL_COMMAND_EVENT_TYPES:[Lcom/netflix/hystrix/HystrixEventType;
         1: .line 43
            invokestatic com.netflix.hystrix.HystrixEventType$ThreadPool.values:()[Lcom/netflix/hystrix/HystrixEventType$ThreadPool;
            putstatic com.netflix.hystrix.HystrixThreadPoolMetrics.ALL_THREADPOOL_EVENT_TYPES:[Lcom/netflix/hystrix/HystrixEventType$ThreadPool;
         2: .line 44
            getstatic com.netflix.hystrix.HystrixThreadPoolMetrics.ALL_THREADPOOL_EVENT_TYPES:[Lcom/netflix/hystrix/HystrixEventType$ThreadPool;
            arraylength
            putstatic com.netflix.hystrix.HystrixThreadPoolMetrics.NUMBER_THREADPOOL_EVENT_TYPES:I
         3: .line 47
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putstatic com.netflix.hystrix.HystrixThreadPoolMetrics.metrics:Ljava/util/concurrent/ConcurrentHashMap;
         4: .line 113
            new com.netflix.hystrix.HystrixThreadPoolMetrics$1
            dup
            invokespecial com.netflix.hystrix.HystrixThreadPoolMetrics$1.<init>:()V
         5: .line 112
            putstatic com.netflix.hystrix.HystrixThreadPoolMetrics.appendEventToBucket:Lrx/functions/Func2;
         6: .line 128
            new com.netflix.hystrix.HystrixThreadPoolMetrics$2
            dup
            invokespecial com.netflix.hystrix.HystrixThreadPoolMetrics$2.<init>:()V
            putstatic com.netflix.hystrix.HystrixThreadPoolMetrics.counterAggregator:Lrx/functions/Func2;
         7: .line 136
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static com.netflix.hystrix.HystrixThreadPoolMetrics getInstance(com.netflix.hystrix.HystrixThreadPoolKey, java.util.concurrent.ThreadPoolExecutor, com.netflix.hystrix.HystrixThreadPoolProperties);
    descriptor: (Lcom/netflix/hystrix/HystrixThreadPoolKey;Ljava/util/concurrent/ThreadPoolExecutor;Lcom/netflix/hystrix/HystrixThreadPoolProperties;)Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=7, args_size=3
        start local 0 // com.netflix.hystrix.HystrixThreadPoolKey key
        start local 1 // java.util.concurrent.ThreadPoolExecutor threadPool
        start local 2 // com.netflix.hystrix.HystrixThreadPoolProperties properties
         0: .line 64
            getstatic com.netflix.hystrix.HystrixThreadPoolMetrics.metrics:Ljava/util/concurrent/ConcurrentHashMap;
            aload 0 /* key */
            invokeinterface com.netflix.hystrix.HystrixThreadPoolKey.name:()Ljava/lang/String;
            invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast com.netflix.hystrix.HystrixThreadPoolMetrics
            astore 3 /* threadPoolMetrics */
        start local 3 // com.netflix.hystrix.HystrixThreadPoolMetrics threadPoolMetrics
         1: .line 65
            aload 3 /* threadPoolMetrics */
            ifnull 3
         2: .line 66
            aload 3 /* threadPoolMetrics */
            areturn
         3: .line 68
      StackMap locals: com.netflix.hystrix.HystrixThreadPoolMetrics
      StackMap stack:
            ldc Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
            dup
            astore 4
            monitorenter
         4: .line 69
            getstatic com.netflix.hystrix.HystrixThreadPoolMetrics.metrics:Ljava/util/concurrent/ConcurrentHashMap;
            aload 0 /* key */
            invokeinterface com.netflix.hystrix.HystrixThreadPoolKey.name:()Ljava/lang/String;
            invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast com.netflix.hystrix.HystrixThreadPoolMetrics
            astore 5 /* existingMetrics */
        start local 5 // com.netflix.hystrix.HystrixThreadPoolMetrics existingMetrics
         5: .line 70
            aload 5 /* existingMetrics */
            ifnull 8
         6: .line 71
            aload 5 /* existingMetrics */
            aload 4
            monitorexit
         7: areturn
         8: .line 73
      StackMap locals: java.lang.Class com.netflix.hystrix.HystrixThreadPoolMetrics
      StackMap stack:
            new com.netflix.hystrix.HystrixThreadPoolMetrics
            dup
            aload 0 /* key */
            aload 1 /* threadPool */
            aload 2 /* properties */
            invokespecial com.netflix.hystrix.HystrixThreadPoolMetrics.<init>:(Lcom/netflix/hystrix/HystrixThreadPoolKey;Ljava/util/concurrent/ThreadPoolExecutor;Lcom/netflix/hystrix/HystrixThreadPoolProperties;)V
            astore 6 /* newThreadPoolMetrics */
        start local 6 // com.netflix.hystrix.HystrixThreadPoolMetrics newThreadPoolMetrics
         9: .line 74
            getstatic com.netflix.hystrix.HystrixThreadPoolMetrics.metrics:Ljava/util/concurrent/ConcurrentHashMap;
            aload 0 /* key */
            invokeinterface com.netflix.hystrix.HystrixThreadPoolKey.name:()Ljava/lang/String;
            aload 6 /* newThreadPoolMetrics */
            invokevirtual java.util.concurrent.ConcurrentHashMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        10: .line 75
            aload 6 /* newThreadPoolMetrics */
            aload 4
            monitorexit
        11: areturn
        end local 6 // com.netflix.hystrix.HystrixThreadPoolMetrics newThreadPoolMetrics
        end local 5 // com.netflix.hystrix.HystrixThreadPoolMetrics existingMetrics
        12: .line 68
      StackMap locals: com.netflix.hystrix.HystrixThreadPoolKey java.util.concurrent.ThreadPoolExecutor com.netflix.hystrix.HystrixThreadPoolProperties com.netflix.hystrix.HystrixThreadPoolMetrics java.lang.Class
      StackMap stack: java.lang.Throwable
            aload 4
            monitorexit
        13: athrow
        end local 3 // com.netflix.hystrix.HystrixThreadPoolMetrics threadPoolMetrics
        end local 2 // com.netflix.hystrix.HystrixThreadPoolProperties properties
        end local 1 // java.util.concurrent.ThreadPoolExecutor threadPool
        end local 0 // com.netflix.hystrix.HystrixThreadPoolKey key
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   14     0                   key  Lcom/netflix/hystrix/HystrixThreadPoolKey;
            0   14     1            threadPool  Ljava/util/concurrent/ThreadPoolExecutor;
            0   14     2            properties  Lcom/netflix/hystrix/HystrixThreadPoolProperties;
            1   14     3     threadPoolMetrics  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
            5   12     5       existingMetrics  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
            9   12     6  newThreadPoolMetrics  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
      Exception table:
        from    to  target  type
           4     7      12  any
           8    11      12  any
          12    13      12  any
    MethodParameters:
            Name  Flags
      key         
      threadPool  
      properties  

  public static com.netflix.hystrix.HystrixThreadPoolMetrics getInstance(com.netflix.hystrix.HystrixThreadPoolKey);
    descriptor: (Lcom/netflix/hystrix/HystrixThreadPoolKey;)Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolKey key
         0: .line 89
            getstatic com.netflix.hystrix.HystrixThreadPoolMetrics.metrics:Ljava/util/concurrent/ConcurrentHashMap;
            aload 0 /* key */
            invokeinterface com.netflix.hystrix.HystrixThreadPoolKey.name:()Ljava/lang/String;
            invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast com.netflix.hystrix.HystrixThreadPoolMetrics
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolKey key
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0   key  Lcom/netflix/hystrix/HystrixThreadPoolKey;
    MethodParameters:
      Name  Flags
      key   

  public static java.util.Collection<com.netflix.hystrix.HystrixThreadPoolMetrics> getInstances();
    descriptor: ()Ljava/util/Collection;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=3, args_size=0
         0: .line 98
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 0 /* threadPoolMetrics */
        start local 0 // java.util.List threadPoolMetrics
         1: .line 99
            getstatic com.netflix.hystrix.HystrixThreadPoolMetrics.metrics:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 2
            goto 5
      StackMap locals: java.util.List top java.util.Iterator
      StackMap stack:
         2: aload 2
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.netflix.hystrix.HystrixThreadPoolMetrics
            astore 1 /* tpm */
        start local 1 // com.netflix.hystrix.HystrixThreadPoolMetrics tpm
         3: .line 100
            aload 1 /* tpm */
            invokestatic com.netflix.hystrix.HystrixThreadPoolMetrics.hasExecutedCommandsOnThread:(Lcom/netflix/hystrix/HystrixThreadPoolMetrics;)Z
            ifeq 5
         4: .line 101
            aload 0 /* threadPoolMetrics */
            aload 1 /* tpm */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 1 // com.netflix.hystrix.HystrixThreadPoolMetrics tpm
         5: .line 99
      StackMap locals:
      StackMap stack:
            aload 2
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         6: .line 105
            aload 0 /* threadPoolMetrics */
            invokestatic java.util.Collections.unmodifiableCollection:(Ljava/util/Collection;)Ljava/util/Collection;
            areturn
        end local 0 // java.util.List threadPoolMetrics
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            1    7     0  threadPoolMetrics  Ljava/util/List<Lcom/netflix/hystrix/HystrixThreadPoolMetrics;>;
            3    5     1                tpm  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
    Signature: ()Ljava/util/Collection<Lcom/netflix/hystrix/HystrixThreadPoolMetrics;>;

  private static boolean hasExecutedCommandsOnThread(com.netflix.hystrix.HystrixThreadPoolMetrics);
    descriptor: (Lcom/netflix/hystrix/HystrixThreadPoolMetrics;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics threadPoolMetrics
         0: .line 109
            aload 0 /* threadPoolMetrics */
            invokevirtual com.netflix.hystrix.HystrixThreadPoolMetrics.getCurrentCompletedTaskCount:()Ljava/lang/Number;
            invokevirtual java.lang.Number.intValue:()I
            ifle 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics threadPoolMetrics
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    2     0  threadPoolMetrics  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
    MethodParameters:
                   Name  Flags
      threadPoolMetrics  

  static void reset();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 143
            getstatic com.netflix.hystrix.HystrixThreadPoolMetrics.metrics:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.clear:()V
         1: .line 144
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>(com.netflix.hystrix.HystrixThreadPoolKey, java.util.concurrent.ThreadPoolExecutor, com.netflix.hystrix.HystrixThreadPoolProperties);
    descriptor: (Lcom/netflix/hystrix/HystrixThreadPoolKey;Ljava/util/concurrent/ThreadPoolExecutor;Lcom/netflix/hystrix/HystrixThreadPoolProperties;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
        start local 1 // com.netflix.hystrix.HystrixThreadPoolKey threadPoolKey
        start local 2 // java.util.concurrent.ThreadPoolExecutor threadPool
        start local 3 // com.netflix.hystrix.HystrixThreadPoolProperties properties
         0: .line 157
            aload 0 /* this */
            aconst_null
            invokespecial com.netflix.hystrix.HystrixMetrics.<init>:(Lcom/netflix/hystrix/util/HystrixRollingNumber;)V
         1: .line 150
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicInteger
            dup
            invokespecial java.util.concurrent.atomic.AtomicInteger.<init>:()V
            putfield com.netflix.hystrix.HystrixThreadPoolMetrics.concurrentExecutionCount:Ljava/util/concurrent/atomic/AtomicInteger;
         2: .line 158
            aload 0 /* this */
            aload 1 /* threadPoolKey */
            putfield com.netflix.hystrix.HystrixThreadPoolMetrics.threadPoolKey:Lcom/netflix/hystrix/HystrixThreadPoolKey;
         3: .line 159
            aload 0 /* this */
            aload 2 /* threadPool */
            putfield com.netflix.hystrix.HystrixThreadPoolMetrics.threadPool:Ljava/util/concurrent/ThreadPoolExecutor;
         4: .line 160
            aload 0 /* this */
            aload 3 /* properties */
            putfield com.netflix.hystrix.HystrixThreadPoolMetrics.properties:Lcom/netflix/hystrix/HystrixThreadPoolProperties;
         5: .line 162
            aload 0 /* this */
            aload 1 /* threadPoolKey */
            aload 3 /* properties */
            invokestatic com.netflix.hystrix.metric.consumer.RollingThreadPoolEventCounterStream.getInstance:(Lcom/netflix/hystrix/HystrixThreadPoolKey;Lcom/netflix/hystrix/HystrixThreadPoolProperties;)Lcom/netflix/hystrix/metric/consumer/RollingThreadPoolEventCounterStream;
            putfield com.netflix.hystrix.HystrixThreadPoolMetrics.rollingCounterStream:Lcom/netflix/hystrix/metric/consumer/RollingThreadPoolEventCounterStream;
         6: .line 163
            aload 0 /* this */
            aload 1 /* threadPoolKey */
            aload 3 /* properties */
            invokestatic com.netflix.hystrix.metric.consumer.CumulativeThreadPoolEventCounterStream.getInstance:(Lcom/netflix/hystrix/HystrixThreadPoolKey;Lcom/netflix/hystrix/HystrixThreadPoolProperties;)Lcom/netflix/hystrix/metric/consumer/CumulativeThreadPoolEventCounterStream;
            putfield com.netflix.hystrix.HystrixThreadPoolMetrics.cumulativeCounterStream:Lcom/netflix/hystrix/metric/consumer/CumulativeThreadPoolEventCounterStream;
         7: .line 164
            aload 0 /* this */
            aload 1 /* threadPoolKey */
            aload 3 /* properties */
            invokestatic com.netflix.hystrix.metric.consumer.RollingThreadPoolMaxConcurrencyStream.getInstance:(Lcom/netflix/hystrix/HystrixThreadPoolKey;Lcom/netflix/hystrix/HystrixThreadPoolProperties;)Lcom/netflix/hystrix/metric/consumer/RollingThreadPoolMaxConcurrencyStream;
            putfield com.netflix.hystrix.HystrixThreadPoolMetrics.rollingThreadPoolMaxConcurrencyStream:Lcom/netflix/hystrix/metric/consumer/RollingThreadPoolMaxConcurrencyStream;
         8: .line 165
            return
        end local 3 // com.netflix.hystrix.HystrixThreadPoolProperties properties
        end local 2 // java.util.concurrent.ThreadPoolExecutor threadPool
        end local 1 // com.netflix.hystrix.HystrixThreadPoolKey threadPoolKey
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    9     0           this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
            0    9     1  threadPoolKey  Lcom/netflix/hystrix/HystrixThreadPoolKey;
            0    9     2     threadPool  Ljava/util/concurrent/ThreadPoolExecutor;
            0    9     3     properties  Lcom/netflix/hystrix/HystrixThreadPoolProperties;
    MethodParameters:
               Name  Flags
      threadPoolKey  
      threadPool     
      properties     

  public java.util.concurrent.ThreadPoolExecutor getThreadPool();
    descriptor: ()Ljava/util/concurrent/ThreadPoolExecutor;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 173
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.threadPool:Ljava/util/concurrent/ThreadPoolExecutor;
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public com.netflix.hystrix.HystrixThreadPoolKey getThreadPoolKey();
    descriptor: ()Lcom/netflix/hystrix/HystrixThreadPoolKey;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 182
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.threadPoolKey:Lcom/netflix/hystrix/HystrixThreadPoolKey;
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public com.netflix.hystrix.HystrixThreadPoolProperties getProperties();
    descriptor: ()Lcom/netflix/hystrix/HystrixThreadPoolProperties;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 191
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.properties:Lcom/netflix/hystrix/HystrixThreadPoolProperties;
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public java.lang.Number getCurrentActiveCount();
    descriptor: ()Ljava/lang/Number;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 200
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.threadPool:Ljava/util/concurrent/ThreadPoolExecutor;
            invokevirtual java.util.concurrent.ThreadPoolExecutor.getActiveCount:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public java.lang.Number getCurrentCompletedTaskCount();
    descriptor: ()Ljava/lang/Number;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 209
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.threadPool:Ljava/util/concurrent/ThreadPoolExecutor;
            invokevirtual java.util.concurrent.ThreadPoolExecutor.getCompletedTaskCount:()J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public java.lang.Number getCurrentCorePoolSize();
    descriptor: ()Ljava/lang/Number;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 218
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.threadPool:Ljava/util/concurrent/ThreadPoolExecutor;
            invokevirtual java.util.concurrent.ThreadPoolExecutor.getCorePoolSize:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public java.lang.Number getCurrentLargestPoolSize();
    descriptor: ()Ljava/lang/Number;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 227
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.threadPool:Ljava/util/concurrent/ThreadPoolExecutor;
            invokevirtual java.util.concurrent.ThreadPoolExecutor.getLargestPoolSize:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public java.lang.Number getCurrentMaximumPoolSize();
    descriptor: ()Ljava/lang/Number;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 236
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.threadPool:Ljava/util/concurrent/ThreadPoolExecutor;
            invokevirtual java.util.concurrent.ThreadPoolExecutor.getMaximumPoolSize:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public java.lang.Number getCurrentPoolSize();
    descriptor: ()Ljava/lang/Number;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 245
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.threadPool:Ljava/util/concurrent/ThreadPoolExecutor;
            invokevirtual java.util.concurrent.ThreadPoolExecutor.getPoolSize:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public java.lang.Number getCurrentTaskCount();
    descriptor: ()Ljava/lang/Number;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 254
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.threadPool:Ljava/util/concurrent/ThreadPoolExecutor;
            invokevirtual java.util.concurrent.ThreadPoolExecutor.getTaskCount:()J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public java.lang.Number getCurrentQueueSize();
    descriptor: ()Ljava/lang/Number;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 263
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.threadPool:Ljava/util/concurrent/ThreadPoolExecutor;
            invokevirtual java.util.concurrent.ThreadPoolExecutor.getQueue:()Ljava/util/concurrent/BlockingQueue;
            invokeinterface java.util.concurrent.BlockingQueue.size:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public void markThreadExecution();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 270
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.concurrentExecutionCount:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.incrementAndGet:()I
            pop
         1: .line 271
            return
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public long getRollingCountThreadsExecuted();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 281
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.rollingCounterStream:Lcom/netflix/hystrix/metric/consumer/RollingThreadPoolEventCounterStream;
            getstatic com.netflix.hystrix.HystrixEventType$ThreadPool.EXECUTED:Lcom/netflix/hystrix/HystrixEventType$ThreadPool;
            invokevirtual com.netflix.hystrix.metric.consumer.RollingThreadPoolEventCounterStream.getLatestCount:(Lcom/netflix/hystrix/HystrixEventType$ThreadPool;)J
            lreturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public long getCumulativeCountThreadsExecuted();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 290
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.cumulativeCounterStream:Lcom/netflix/hystrix/metric/consumer/CumulativeThreadPoolEventCounterStream;
            getstatic com.netflix.hystrix.HystrixEventType$ThreadPool.EXECUTED:Lcom/netflix/hystrix/HystrixEventType$ThreadPool;
            invokevirtual com.netflix.hystrix.metric.consumer.CumulativeThreadPoolEventCounterStream.getLatestCount:(Lcom/netflix/hystrix/HystrixEventType$ThreadPool;)J
            lreturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public long getRollingCountThreadsRejected();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 301
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.rollingCounterStream:Lcom/netflix/hystrix/metric/consumer/RollingThreadPoolEventCounterStream;
            getstatic com.netflix.hystrix.HystrixEventType$ThreadPool.REJECTED:Lcom/netflix/hystrix/HystrixEventType$ThreadPool;
            invokevirtual com.netflix.hystrix.metric.consumer.RollingThreadPoolEventCounterStream.getLatestCount:(Lcom/netflix/hystrix/HystrixEventType$ThreadPool;)J
            lreturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public long getCumulativeCountThreadsRejected();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 310
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.cumulativeCounterStream:Lcom/netflix/hystrix/metric/consumer/CumulativeThreadPoolEventCounterStream;
            getstatic com.netflix.hystrix.HystrixEventType$ThreadPool.REJECTED:Lcom/netflix/hystrix/HystrixEventType$ThreadPool;
            invokevirtual com.netflix.hystrix.metric.consumer.CumulativeThreadPoolEventCounterStream.getLatestCount:(Lcom/netflix/hystrix/HystrixEventType$ThreadPool;)J
            lreturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public long getRollingCount(com.netflix.hystrix.HystrixEventType$ThreadPool);
    descriptor: (Lcom/netflix/hystrix/HystrixEventType$ThreadPool;)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
        start local 1 // com.netflix.hystrix.HystrixEventType$ThreadPool event
         0: .line 314
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.rollingCounterStream:Lcom/netflix/hystrix/metric/consumer/RollingThreadPoolEventCounterStream;
            aload 1 /* event */
            invokevirtual com.netflix.hystrix.metric.consumer.RollingThreadPoolEventCounterStream.getLatestCount:(Lcom/netflix/hystrix/HystrixEventType$ThreadPool;)J
            lreturn
        end local 1 // com.netflix.hystrix.HystrixEventType$ThreadPool event
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
            0    1     1  event  Lcom/netflix/hystrix/HystrixEventType$ThreadPool;
    MethodParameters:
       Name  Flags
      event  

  public long getCumulativeCount(com.netflix.hystrix.HystrixEventType$ThreadPool);
    descriptor: (Lcom/netflix/hystrix/HystrixEventType$ThreadPool;)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
        start local 1 // com.netflix.hystrix.HystrixEventType$ThreadPool event
         0: .line 318
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.cumulativeCounterStream:Lcom/netflix/hystrix/metric/consumer/CumulativeThreadPoolEventCounterStream;
            aload 1 /* event */
            invokevirtual com.netflix.hystrix.metric.consumer.CumulativeThreadPoolEventCounterStream.getLatestCount:(Lcom/netflix/hystrix/HystrixEventType$ThreadPool;)J
            lreturn
        end local 1 // com.netflix.hystrix.HystrixEventType$ThreadPool event
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
            0    1     1  event  Lcom/netflix/hystrix/HystrixEventType$ThreadPool;
    MethodParameters:
       Name  Flags
      event  

  public long getCumulativeCount(com.netflix.hystrix.util.HystrixRollingNumberEvent);
    descriptor: (Lcom/netflix/hystrix/util/HystrixRollingNumberEvent;)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
        start local 1 // com.netflix.hystrix.util.HystrixRollingNumberEvent event
         0: .line 323
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.cumulativeCounterStream:Lcom/netflix/hystrix/metric/consumer/CumulativeThreadPoolEventCounterStream;
            aload 1 /* event */
            invokestatic com.netflix.hystrix.HystrixEventType$ThreadPool.from:(Lcom/netflix/hystrix/util/HystrixRollingNumberEvent;)Lcom/netflix/hystrix/HystrixEventType$ThreadPool;
            invokevirtual com.netflix.hystrix.metric.consumer.CumulativeThreadPoolEventCounterStream.getLatestCount:(Lcom/netflix/hystrix/HystrixEventType$ThreadPool;)J
            lreturn
        end local 1 // com.netflix.hystrix.util.HystrixRollingNumberEvent event
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
            0    1     1  event  Lcom/netflix/hystrix/util/HystrixRollingNumberEvent;
    MethodParameters:
       Name  Flags
      event  

  public long getRollingCount(com.netflix.hystrix.util.HystrixRollingNumberEvent);
    descriptor: (Lcom/netflix/hystrix/util/HystrixRollingNumberEvent;)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
        start local 1 // com.netflix.hystrix.util.HystrixRollingNumberEvent event
         0: .line 328
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.rollingCounterStream:Lcom/netflix/hystrix/metric/consumer/RollingThreadPoolEventCounterStream;
            aload 1 /* event */
            invokestatic com.netflix.hystrix.HystrixEventType$ThreadPool.from:(Lcom/netflix/hystrix/util/HystrixRollingNumberEvent;)Lcom/netflix/hystrix/HystrixEventType$ThreadPool;
            invokevirtual com.netflix.hystrix.metric.consumer.RollingThreadPoolEventCounterStream.getLatestCount:(Lcom/netflix/hystrix/HystrixEventType$ThreadPool;)J
            lreturn
        end local 1 // com.netflix.hystrix.util.HystrixRollingNumberEvent event
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;
            0    1     1  event  Lcom/netflix/hystrix/util/HystrixRollingNumberEvent;
    MethodParameters:
       Name  Flags
      event  

  public void markThreadCompletion();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 335
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.concurrentExecutionCount:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.decrementAndGet:()I
            pop
         1: .line 336
            return
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public long getRollingMaxActiveThreads();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 346
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.rollingThreadPoolMaxConcurrencyStream:Lcom/netflix/hystrix/metric/consumer/RollingThreadPoolMaxConcurrencyStream;
            invokevirtual com.netflix.hystrix.metric.consumer.RollingThreadPoolMaxConcurrencyStream.getLatestRollingMax:()J
            lreturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public void markThreadRejection();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
         0: .line 353
            aload 0 /* this */
            getfield com.netflix.hystrix.HystrixThreadPoolMetrics.concurrentExecutionCount:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.decrementAndGet:()I
            pop
         1: .line 354
            return
        end local 0 // com.netflix.hystrix.HystrixThreadPoolMetrics this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/netflix/hystrix/HystrixThreadPoolMetrics;

  public static rx.functions.Func0<java.lang.Integer> getCurrentConcurrencyThunk(com.netflix.hystrix.HystrixThreadPoolKey);
    descriptor: (Lcom/netflix/hystrix/HystrixThreadPoolKey;)Lrx/functions/Func0;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPoolKey threadPoolKey
         0: .line 357
            new com.netflix.hystrix.HystrixThreadPoolMetrics$3
            dup
            aload 0 /* threadPoolKey */
            invokespecial com.netflix.hystrix.HystrixThreadPoolMetrics$3.<init>:(Lcom/netflix/hystrix/HystrixThreadPoolKey;)V
            areturn
        end local 0 // com.netflix.hystrix.HystrixThreadPoolKey threadPoolKey
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    1     0  threadPoolKey  Lcom/netflix/hystrix/HystrixThreadPoolKey;
    Signature: (Lcom/netflix/hystrix/HystrixThreadPoolKey;)Lrx/functions/Func0<Ljava/lang/Integer;>;
    MethodParameters:
               Name  Flags
      threadPoolKey  final
}
SourceFile: "HystrixThreadPoolMetrics.java"
NestMembers:
  com.netflix.hystrix.HystrixThreadPoolMetrics$1  com.netflix.hystrix.HystrixThreadPoolMetrics$2  com.netflix.hystrix.HystrixThreadPoolMetrics$3
InnerClasses:
  public final ThreadPool = com.netflix.hystrix.HystrixEventType$ThreadPool of com.netflix.hystrix.HystrixEventType
  com.netflix.hystrix.HystrixThreadPoolMetrics$1
  com.netflix.hystrix.HystrixThreadPoolMetrics$2
  com.netflix.hystrix.HystrixThreadPoolMetrics$3