public class com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream extends com.netflix.hystrix.metric.consumer.RollingDistributionStream<com.netflix.hystrix.metric.HystrixCommandCompletion>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream
  super_class: com.netflix.hystrix.metric.consumer.RollingDistributionStream
{
  private static final java.util.concurrent.ConcurrentMap<java.lang.String, com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream> streams;
    descriptor: Ljava/util/concurrent/ConcurrentMap;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentMap<Ljava/lang/String;Lcom/netflix/hystrix/metric/consumer/RollingCommandUserLatencyDistributionStream;>;

  private static final rx.functions.Func2<org.HdrHistogram.Histogram, com.netflix.hystrix.metric.HystrixCommandCompletion, org.HdrHistogram.Histogram> addValuesToBucket;
    descriptor: Lrx/functions/Func2;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Lrx/functions/Func2<Lorg/HdrHistogram/Histogram;Lcom/netflix/hystrix/metric/HystrixCommandCompletion;Lorg/HdrHistogram/Histogram;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 52
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putstatic com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream.streams:Ljava/util/concurrent/ConcurrentMap;
         1: .line 54
            new com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream$1
            dup
            invokespecial com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream$1.<init>:()V
            putstatic com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream.addValuesToBucket:Lrx/functions/Func2;
         2: .line 62
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream getInstance(com.netflix.hystrix.HystrixCommandKey, com.netflix.hystrix.HystrixCommandProperties);
    descriptor: (Lcom/netflix/hystrix/HystrixCommandKey;Lcom/netflix/hystrix/HystrixCommandProperties;)Lcom/netflix/hystrix/metric/consumer/RollingCommandUserLatencyDistributionStream;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // com.netflix.hystrix.HystrixCommandKey commandKey
        start local 1 // com.netflix.hystrix.HystrixCommandProperties properties
         0: .line 65
            aload 1 /* properties */
            invokevirtual com.netflix.hystrix.HystrixCommandProperties.metricsRollingPercentileWindowInMilliseconds:()Lcom/netflix/hystrix/strategy/properties/HystrixProperty;
            invokeinterface com.netflix.hystrix.strategy.properties.HystrixProperty.get:()Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            istore 2 /* percentileMetricWindow */
        start local 2 // int percentileMetricWindow
         1: .line 66
            aload 1 /* properties */
            invokevirtual com.netflix.hystrix.HystrixCommandProperties.metricsRollingPercentileWindowBuckets:()Lcom/netflix/hystrix/strategy/properties/HystrixProperty;
            invokeinterface com.netflix.hystrix.strategy.properties.HystrixProperty.get:()Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            istore 3 /* numPercentileBuckets */
        start local 3 // int numPercentileBuckets
         2: .line 67
            iload 2 /* percentileMetricWindow */
            iload 3 /* numPercentileBuckets */
            idiv
            istore 4 /* percentileBucketSizeInMs */
        start local 4 // int percentileBucketSizeInMs
         3: .line 69
            aload 0 /* commandKey */
            iload 3 /* numPercentileBuckets */
            iload 4 /* percentileBucketSizeInMs */
            invokestatic com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream.getInstance:(Lcom/netflix/hystrix/HystrixCommandKey;II)Lcom/netflix/hystrix/metric/consumer/RollingCommandUserLatencyDistributionStream;
            areturn
        end local 4 // int percentileBucketSizeInMs
        end local 3 // int numPercentileBuckets
        end local 2 // int percentileMetricWindow
        end local 1 // com.netflix.hystrix.HystrixCommandProperties properties
        end local 0 // com.netflix.hystrix.HystrixCommandKey commandKey
      LocalVariableTable:
        Start  End  Slot                      Name  Signature
            0    4     0                commandKey  Lcom/netflix/hystrix/HystrixCommandKey;
            0    4     1                properties  Lcom/netflix/hystrix/HystrixCommandProperties;
            1    4     2    percentileMetricWindow  I
            2    4     3      numPercentileBuckets  I
            3    4     4  percentileBucketSizeInMs  I
    MethodParameters:
            Name  Flags
      commandKey  
      properties  

  public static com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream getInstance(com.netflix.hystrix.HystrixCommandKey, int, int);
    descriptor: (Lcom/netflix/hystrix/HystrixCommandKey;II)Lcom/netflix/hystrix/metric/consumer/RollingCommandUserLatencyDistributionStream;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=7, args_size=3
        start local 0 // com.netflix.hystrix.HystrixCommandKey commandKey
        start local 1 // int numBuckets
        start local 2 // int bucketSizeInMs
         0: .line 73
            getstatic com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream.streams:Ljava/util/concurrent/ConcurrentMap;
            aload 0 /* commandKey */
            invokeinterface com.netflix.hystrix.HystrixCommandKey.name:()Ljava/lang/String;
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream
            astore 3 /* initialStream */
        start local 3 // com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream initialStream
         1: .line 74
            aload 3 /* initialStream */
            ifnull 3
         2: .line 75
            aload 3 /* initialStream */
            areturn
         3: .line 77
      StackMap locals: com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream
      StackMap stack:
            ldc Lcom/netflix/hystrix/metric/consumer/RollingCommandUserLatencyDistributionStream;
            dup
            astore 4
            monitorenter
         4: .line 78
            getstatic com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream.streams:Ljava/util/concurrent/ConcurrentMap;
            aload 0 /* commandKey */
            invokeinterface com.netflix.hystrix.HystrixCommandKey.name:()Ljava/lang/String;
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream
            astore 5 /* existingStream */
        start local 5 // com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream existingStream
         5: .line 79
            aload 5 /* existingStream */
            ifnonnull 10
         6: .line 80
            new com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream
            dup
            aload 0 /* commandKey */
            iload 1 /* numBuckets */
            iload 2 /* bucketSizeInMs */
            invokespecial com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream.<init>:(Lcom/netflix/hystrix/HystrixCommandKey;II)V
            astore 6 /* newStream */
        start local 6 // com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream newStream
         7: .line 81
            getstatic com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream.streams:Ljava/util/concurrent/ConcurrentMap;
            aload 0 /* commandKey */
            invokeinterface com.netflix.hystrix.HystrixCommandKey.name:()Ljava/lang/String;
            aload 6 /* newStream */
            invokeinterface java.util.concurrent.ConcurrentMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         8: .line 82
            aload 6 /* newStream */
            aload 4
            monitorexit
         9: areturn
        end local 6 // com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream newStream
        10: .line 84
      StackMap locals: java.lang.Class com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream
      StackMap stack:
            aload 5 /* existingStream */
            aload 4
            monitorexit
        11: areturn
        end local 5 // com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream existingStream
        12: .line 77
      StackMap locals: com.netflix.hystrix.HystrixCommandKey int int com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream java.lang.Class
      StackMap stack: java.lang.Throwable
            aload 4
            monitorexit
        13: athrow
        end local 3 // com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream initialStream
        end local 2 // int bucketSizeInMs
        end local 1 // int numBuckets
        end local 0 // com.netflix.hystrix.HystrixCommandKey commandKey
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   14     0      commandKey  Lcom/netflix/hystrix/HystrixCommandKey;
            0   14     1      numBuckets  I
            0   14     2  bucketSizeInMs  I
            1   14     3   initialStream  Lcom/netflix/hystrix/metric/consumer/RollingCommandUserLatencyDistributionStream;
            5   12     5  existingStream  Lcom/netflix/hystrix/metric/consumer/RollingCommandUserLatencyDistributionStream;
            7   10     6       newStream  Lcom/netflix/hystrix/metric/consumer/RollingCommandUserLatencyDistributionStream;
      Exception table:
        from    to  target  type
           4     9      12  any
          10    11      12  any
          12    13      12  any
    MethodParameters:
                Name  Flags
      commandKey      
      numBuckets      
      bucketSizeInMs  

  public static void reset();
    descriptor: ()V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 91
            getstatic com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream.streams:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.clear:()V
         1: .line 92
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>(com.netflix.hystrix.HystrixCommandKey, int, int);
    descriptor: (Lcom/netflix/hystrix/HystrixCommandKey;II)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream this
        start local 1 // com.netflix.hystrix.HystrixCommandKey commandKey
        start local 2 // int numPercentileBuckets
        start local 3 // int percentileBucketSizeInMs
         0: .line 95
            aload 0 /* this */
            aload 1 /* commandKey */
            invokestatic com.netflix.hystrix.metric.HystrixCommandCompletionStream.getInstance:(Lcom/netflix/hystrix/HystrixCommandKey;)Lcom/netflix/hystrix/metric/HystrixCommandCompletionStream;
            iload 2 /* numPercentileBuckets */
            iload 3 /* percentileBucketSizeInMs */
            getstatic com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream.addValuesToBucket:Lrx/functions/Func2;
            invokespecial com.netflix.hystrix.metric.consumer.RollingDistributionStream.<init>:(Lcom/netflix/hystrix/metric/HystrixEventStream;IILrx/functions/Func2;)V
         1: .line 96
            return
        end local 3 // int percentileBucketSizeInMs
        end local 2 // int numPercentileBuckets
        end local 1 // com.netflix.hystrix.HystrixCommandKey commandKey
        end local 0 // com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream this
      LocalVariableTable:
        Start  End  Slot                      Name  Signature
            0    2     0                      this  Lcom/netflix/hystrix/metric/consumer/RollingCommandUserLatencyDistributionStream;
            0    2     1                commandKey  Lcom/netflix/hystrix/HystrixCommandKey;
            0    2     2      numPercentileBuckets  I
            0    2     3  percentileBucketSizeInMs  I
    MethodParameters:
                          Name  Flags
      commandKey                
      numPercentileBuckets      
      percentileBucketSizeInMs  
}
Signature: Lcom/netflix/hystrix/metric/consumer/RollingDistributionStream<Lcom/netflix/hystrix/metric/HystrixCommandCompletion;>;
SourceFile: "RollingCommandUserLatencyDistributionStream.java"
NestMembers:
  com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream$1
InnerClasses:
  com.netflix.hystrix.metric.consumer.RollingCommandUserLatencyDistributionStream$1