public class com.netflix.hystrix.HystrixThreadPool$Factory
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: com.netflix.hystrix.HystrixThreadPool$Factory
  super_class: java.lang.Object
{
  static final java.util.concurrent.ConcurrentHashMap<java.lang.String, com.netflix.hystrix.HystrixThreadPool> threadPools;
    descriptor: Ljava/util/concurrent/ConcurrentHashMap;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentHashMap<Ljava/lang/String;Lcom/netflix/hystrix/HystrixThreadPool;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 93
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putstatic com.netflix.hystrix.HystrixThreadPool$Factory.threadPools:Ljava/util/concurrent/ConcurrentHashMap;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.netflix.hystrix.HystrixThreadPool$Factory this
         0: .line 88
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // com.netflix.hystrix.HystrixThreadPool$Factory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/netflix/hystrix/HystrixThreadPool$Factory;

  static com.netflix.hystrix.HystrixThreadPool getInstance(com.netflix.hystrix.HystrixThreadPoolKey, com.netflix.hystrix.HystrixThreadPoolProperties$Setter);
    descriptor: (Lcom/netflix/hystrix/HystrixThreadPoolKey;Lcom/netflix/hystrix/HystrixThreadPoolProperties$Setter;)Lcom/netflix/hystrix/HystrixThreadPool;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=6, locals=5, args_size=2
        start local 0 // com.netflix.hystrix.HystrixThreadPoolKey threadPoolKey
        start local 1 // com.netflix.hystrix.HystrixThreadPoolProperties$Setter propertiesBuilder
         0: .line 104
            aload 0 /* threadPoolKey */
            invokeinterface com.netflix.hystrix.HystrixThreadPoolKey.name:()Ljava/lang/String;
            astore 2 /* key */
        start local 2 // java.lang.String key
         1: .line 107
            getstatic com.netflix.hystrix.HystrixThreadPool$Factory.threadPools:Ljava/util/concurrent/ConcurrentHashMap;
            aload 2 /* key */
            invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast com.netflix.hystrix.HystrixThreadPool
            astore 3 /* previouslyCached */
        start local 3 // com.netflix.hystrix.HystrixThreadPool previouslyCached
         2: .line 108
            aload 3 /* previouslyCached */
            ifnull 4
         3: .line 109
            aload 3 /* previouslyCached */
            areturn
         4: .line 113
      StackMap locals: java.lang.String com.netflix.hystrix.HystrixThreadPool
      StackMap stack:
            ldc Lcom/netflix/hystrix/HystrixThreadPool;
            dup
            astore 4
            monitorenter
         5: .line 114
            getstatic com.netflix.hystrix.HystrixThreadPool$Factory.threadPools:Ljava/util/concurrent/ConcurrentHashMap;
            aload 2 /* key */
            invokevirtual java.util.concurrent.ConcurrentHashMap.containsKey:(Ljava/lang/Object;)Z
            ifne 7
         6: .line 115
            getstatic com.netflix.hystrix.HystrixThreadPool$Factory.threadPools:Ljava/util/concurrent/ConcurrentHashMap;
            aload 2 /* key */
            new com.netflix.hystrix.HystrixThreadPool$HystrixThreadPoolDefault
            dup
            aload 0 /* threadPoolKey */
            aload 1 /* propertiesBuilder */
            invokespecial com.netflix.hystrix.HystrixThreadPool$HystrixThreadPoolDefault.<init>:(Lcom/netflix/hystrix/HystrixThreadPoolKey;Lcom/netflix/hystrix/HystrixThreadPoolProperties$Setter;)V
            invokevirtual java.util.concurrent.ConcurrentHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         7: .line 113
      StackMap locals: java.lang.Class
      StackMap stack:
            aload 4
            monitorexit
         8: goto 11
      StackMap locals:
      StackMap stack: java.lang.Throwable
         9: aload 4
            monitorexit
        10: athrow
        11: .line 118
      StackMap locals:
      StackMap stack:
            getstatic com.netflix.hystrix.HystrixThreadPool$Factory.threadPools:Ljava/util/concurrent/ConcurrentHashMap;
            aload 2 /* key */
            invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast com.netflix.hystrix.HystrixThreadPool
            areturn
        end local 3 // com.netflix.hystrix.HystrixThreadPool previouslyCached
        end local 2 // java.lang.String key
        end local 1 // com.netflix.hystrix.HystrixThreadPoolProperties$Setter propertiesBuilder
        end local 0 // com.netflix.hystrix.HystrixThreadPoolKey threadPoolKey
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   12     0      threadPoolKey  Lcom/netflix/hystrix/HystrixThreadPoolKey;
            0   12     1  propertiesBuilder  Lcom/netflix/hystrix/HystrixThreadPoolProperties$Setter;
            1   12     2                key  Ljava/lang/String;
            2   12     3   previouslyCached  Lcom/netflix/hystrix/HystrixThreadPool;
      Exception table:
        from    to  target  type
           5     8       9  any
           9    10       9  any
    MethodParameters:
                   Name  Flags
      threadPoolKey      
      propertiesBuilder  

  static synchronized void shutdown();
    descriptor: ()V
    flags: (0x0028) ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=1, locals=2, args_size=0
         0: .line 129
            getstatic com.netflix.hystrix.HystrixThreadPool$Factory.threadPools:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 1
            goto 3
      StackMap locals: top java.util.Iterator
      StackMap stack:
         1: aload 1
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.netflix.hystrix.HystrixThreadPool
            astore 0 /* pool */
        start local 0 // com.netflix.hystrix.HystrixThreadPool pool
         2: .line 130
            aload 0 /* pool */
            invokeinterface com.netflix.hystrix.HystrixThreadPool.getExecutor:()Ljava/util/concurrent/ExecutorService;
            invokeinterface java.util.concurrent.ExecutorService.shutdown:()V
        end local 0 // com.netflix.hystrix.HystrixThreadPool pool
         3: .line 129
      StackMap locals:
      StackMap stack:
            aload 1
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         4: .line 132
            getstatic com.netflix.hystrix.HystrixThreadPool$Factory.threadPools:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.clear:()V
         5: .line 133
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            2    3     0  pool  Lcom/netflix/hystrix/HystrixThreadPool;

  static synchronized void shutdown(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)V
    flags: (0x0028) ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=6, args_size=2
        start local 0 // long timeout
        start local 2 // java.util.concurrent.TimeUnit unit
         0: .line 143
            getstatic com.netflix.hystrix.HystrixThreadPool$Factory.threadPools:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 3
      StackMap locals: long java.util.concurrent.TimeUnit top java.util.Iterator
      StackMap stack:
         1: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.netflix.hystrix.HystrixThreadPool
            astore 3 /* pool */
        start local 3 // com.netflix.hystrix.HystrixThreadPool pool
         2: .line 144
            aload 3 /* pool */
            invokeinterface com.netflix.hystrix.HystrixThreadPool.getExecutor:()Ljava/util/concurrent/ExecutorService;
            invokeinterface java.util.concurrent.ExecutorService.shutdown:()V
        end local 3 // com.netflix.hystrix.HystrixThreadPool pool
         3: .line 143
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         4: .line 146
            getstatic com.netflix.hystrix.HystrixThreadPool$Factory.threadPools:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 10
      StackMap locals:
      StackMap stack:
         5: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.netflix.hystrix.HystrixThreadPool
            astore 3 /* pool */
        start local 3 // com.netflix.hystrix.HystrixThreadPool pool
         6: .line 148
      StackMap locals: long java.util.concurrent.TimeUnit com.netflix.hystrix.HystrixThreadPool java.util.Iterator
      StackMap stack:
            aload 3 /* pool */
            invokeinterface com.netflix.hystrix.HystrixThreadPool.getExecutor:()Ljava/util/concurrent/ExecutorService;
            lload 0 /* timeout */
            aload 2 /* unit */
            invokeinterface java.util.concurrent.ExecutorService.awaitTermination:(JLjava/util/concurrent/TimeUnit;)Z
            ifeq 6
         7: .line 150
            goto 10
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
         8: astore 5 /* e */
        start local 5 // java.lang.InterruptedException e
         9: .line 151
            new java.lang.RuntimeException
            dup
            ldc "Interrupted while waiting for thread-pools to terminate. Pools may not be correctly shutdown or cleared."
            aload 5 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.lang.InterruptedException e
        end local 3 // com.netflix.hystrix.HystrixThreadPool pool
        10: .line 146
      StackMap locals: long java.util.concurrent.TimeUnit top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        11: .line 154
            getstatic com.netflix.hystrix.HystrixThreadPool$Factory.threadPools:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.clear:()V
        12: .line 155
            return
        end local 2 // java.util.concurrent.TimeUnit unit
        end local 0 // long timeout
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   13     0  timeout  J
            0   13     2     unit  Ljava/util/concurrent/TimeUnit;
            2    3     3     pool  Lcom/netflix/hystrix/HystrixThreadPool;
            6   10     3     pool  Lcom/netflix/hystrix/HystrixThreadPool;
            9   10     5        e  Ljava/lang/InterruptedException;
      Exception table:
        from    to  target  type
           6     7       8  Class java.lang.InterruptedException
    MethodParameters:
         Name  Flags
      timeout  
      unit     
}
SourceFile: "HystrixThreadPool.java"
NestHost: com.netflix.hystrix.HystrixThreadPool
InnerClasses:
  public Factory = com.netflix.hystrix.HystrixThreadPool$Factory of com.netflix.hystrix.HystrixThreadPool
  public HystrixThreadPoolDefault = com.netflix.hystrix.HystrixThreadPool$HystrixThreadPoolDefault of com.netflix.hystrix.HystrixThreadPool
  public Setter = com.netflix.hystrix.HystrixThreadPoolProperties$Setter of com.netflix.hystrix.HystrixThreadPoolProperties