public class com.carrotsearch.hppc.CharDoubleHashMap implements com.carrotsearch.hppc.CharDoubleMap, com.carrotsearch.hppc.Preallocable, java.lang.Cloneable
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: com.carrotsearch.hppc.CharDoubleHashMap
  super_class: java.lang.Object
{
  public char[] keys;
    descriptor: [C
    flags: (0x0001) ACC_PUBLIC

  public double[] values;
    descriptor: [D
    flags: (0x0001) ACC_PUBLIC

  protected int keyMixer;
    descriptor: I
    flags: (0x0004) ACC_PROTECTED

  protected int assigned;
    descriptor: I
    flags: (0x0004) ACC_PROTECTED

  protected int mask;
    descriptor: I
    flags: (0x0004) ACC_PROTECTED

  protected int resizeAt;
    descriptor: I
    flags: (0x0004) ACC_PROTECTED

  protected boolean hasEmptyKey;
    descriptor: Z
    flags: (0x0004) ACC_PROTECTED

  protected double loadFactor;
    descriptor: D
    flags: (0x0004) ACC_PROTECTED

  protected com.carrotsearch.hppc.HashOrderMixingStrategy orderMixer;
    descriptor: Lcom/carrotsearch/hppc/HashOrderMixingStrategy;
    flags: (0x0004) ACC_PROTECTED

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 27
            ldc Lcom/carrotsearch/hppc/CharDoubleHashMap;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
         0: .line 95
            aload 0 /* this */
            iconst_4
            invokespecial com.carrotsearch.hppc.CharDoubleHashMap.<init>:(I)V
         1: .line 96
            return
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/carrotsearch/hppc/CharDoubleHashMap;

  public void <init>(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // int expectedElements
         0: .line 106
            aload 0 /* this */
            iload 1 /* expectedElements */
            ldc 0.75
            invokespecial com.carrotsearch.hppc.CharDoubleHashMap.<init>:(ID)V
         1: .line 107
            return
        end local 1 // int expectedElements
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    2     0              this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    2     1  expectedElements  I
    MethodParameters:
                  Name  Flags
      expectedElements  

  public void <init>(int, double);
    descriptor: (ID)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // int expectedElements
        start local 2 // double loadFactor
         0: .line 120
            aload 0 /* this */
            iload 1 /* expectedElements */
            dload 2 /* loadFactor */
            invokestatic com.carrotsearch.hppc.HashOrderMixing.defaultStrategy:()Lcom/carrotsearch/hppc/HashOrderMixingStrategy;
            invokespecial com.carrotsearch.hppc.CharDoubleHashMap.<init>:(IDLcom/carrotsearch/hppc/HashOrderMixingStrategy;)V
         1: .line 121
            return
        end local 2 // double loadFactor
        end local 1 // int expectedElements
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    2     0              this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    2     1  expectedElements  I
            0    2     2        loadFactor  D
    MethodParameters:
                  Name  Flags
      expectedElements  
      loadFactor        

  public void <init>(int, double, com.carrotsearch.hppc.HashOrderMixingStrategy);
    descriptor: (IDLcom/carrotsearch/hppc/HashOrderMixingStrategy;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=4
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // int expectedElements
        start local 2 // double loadFactor
        start local 4 // com.carrotsearch.hppc.HashOrderMixingStrategy orderMixer
         0: .line 136
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 137
            aload 0 /* this */
            aload 4 /* orderMixer */
            putfield com.carrotsearch.hppc.CharDoubleHashMap.orderMixer:Lcom/carrotsearch/hppc/HashOrderMixingStrategy;
         2: .line 138
            aload 0 /* this */
            aload 0 /* this */
            dload 2 /* loadFactor */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.verifyLoadFactor:(D)D
            putfield com.carrotsearch.hppc.CharDoubleHashMap.loadFactor:D
         3: .line 139
            aload 0 /* this */
            iload 1 /* expectedElements */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.ensureCapacity:(I)V
         4: .line 140
            return
        end local 4 // com.carrotsearch.hppc.HashOrderMixingStrategy orderMixer
        end local 2 // double loadFactor
        end local 1 // int expectedElements
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    5     0              this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    5     1  expectedElements  I
            0    5     2        loadFactor  D
            0    5     4        orderMixer  Lcom/carrotsearch/hppc/HashOrderMixingStrategy;
    MethodParameters:
                  Name  Flags
      expectedElements  
      loadFactor        
      orderMixer        

  public void <init>(com.carrotsearch.hppc.CharDoubleAssociativeContainer);
    descriptor: (Lcom/carrotsearch/hppc/CharDoubleAssociativeContainer;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // com.carrotsearch.hppc.CharDoubleAssociativeContainer container
         0: .line 146
            aload 0 /* this */
            aload 1 /* container */
            invokeinterface com.carrotsearch.hppc.CharDoubleAssociativeContainer.size:()I
            invokespecial com.carrotsearch.hppc.CharDoubleHashMap.<init>:(I)V
         1: .line 147
            aload 0 /* this */
            aload 1 /* container */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.putAll:(Lcom/carrotsearch/hppc/CharDoubleAssociativeContainer;)I
            pop
         2: .line 148
            return
        end local 1 // com.carrotsearch.hppc.CharDoubleAssociativeContainer container
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0       this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    3     1  container  Lcom/carrotsearch/hppc/CharDoubleAssociativeContainer;
    MethodParameters:
           Name  Flags
      container  

  public double put(char, double);
    descriptor: (CD)D
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=10, args_size=3
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // char key
        start local 2 // double value
         0: .line 155
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            if_icmplt 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 157
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 4 /* mask */
        start local 4 // int mask
         2: .line 158
            iload 1 /* key */
            ifne 7
         3: .line 159
            aload 0 /* this */
            iconst_1
            putfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
         4: .line 160
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 4 /* mask */
            iconst_1
            iadd
            daload
            dstore 5 /* previousValue */
        start local 5 // double previousValue
         5: .line 161
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 4 /* mask */
            iconst_1
            iadd
            dload 2 /* value */
            dastore
         6: .line 162
            dload 5 /* previousValue */
            dreturn
        end local 5 // double previousValue
         7: .line 164
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 5 /* keys */
        start local 5 // char[] keys
         8: .line 165
            aload 0 /* this */
            iload 1 /* key */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.hashKey:(C)I
            iload 4 /* mask */
            iand
            istore 6 /* slot */
        start local 6 // int slot
         9: .line 168
            goto 15
        start local 7 // char existing
        10: .line 169
      StackMap locals: char[] int int
      StackMap stack:
            iload 7 /* existing */
            iload 1 /* key */
            if_icmpne 14
        11: .line 170
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 6 /* slot */
            daload
            dstore 8 /* previousValue */
        start local 8 // double previousValue
        12: .line 171
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 6 /* slot */
            dload 2 /* value */
            dastore
        13: .line 172
            dload 8 /* previousValue */
            dreturn
        end local 8 // double previousValue
        14: .line 174
      StackMap locals:
      StackMap stack:
            iload 6 /* slot */
            iconst_1
            iadd
            iload 4 /* mask */
            iand
            istore 6 /* slot */
        end local 7 // char existing
        15: .line 168
      StackMap locals:
      StackMap stack:
            aload 5 /* keys */
            iload 6 /* slot */
            caload
            dup
            istore 7 /* existing */
        start local 7 // char existing
        16: ifne 10
        17: .line 177
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.resizeAt:I
            if_icmpne 20
        18: .line 178
            aload 0 /* this */
            iload 6 /* slot */
            iload 1 /* key */
            dload 2 /* value */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.allocateThenInsertThenRehash:(ICD)V
        19: .line 179
            goto 22
        20: .line 180
      StackMap locals: int
      StackMap stack:
            aload 5 /* keys */
            iload 6 /* slot */
            iload 1 /* key */
            castore
        21: .line 181
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 6 /* slot */
            dload 2 /* value */
            dastore
        22: .line 184
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
            iconst_1
            iadd
            putfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
        23: .line 185
            dconst_0
            dreturn
        end local 7 // char existing
        end local 6 // int slot
        end local 5 // char[] keys
        end local 4 // int mask
        end local 2 // double value
        end local 1 // char key
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   24     0           this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   24     1            key  C
            0   24     2          value  D
            2   24     4           mask  I
            5    7     5  previousValue  D
            8   24     5           keys  [C
            9   24     6           slot  I
           10   15     7       existing  C
           16   24     7       existing  C
           12   14     8  previousValue  D
    MethodParameters:
       Name  Flags
      key    
      value  

  public int putAll(com.carrotsearch.hppc.CharDoubleAssociativeContainer);
    descriptor: (Lcom/carrotsearch/hppc/CharDoubleAssociativeContainer;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // com.carrotsearch.hppc.CharDoubleAssociativeContainer container
         0: .line 194
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            istore 2 /* count */
        start local 2 // int count
         1: .line 195
            aload 1 /* container */
            invokeinterface com.carrotsearch.hppc.CharDoubleAssociativeContainer.iterator:()Ljava/util/Iterator;
            astore 4
            goto 4
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap com.carrotsearch.hppc.CharDoubleAssociativeContainer int top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.carrotsearch.hppc.cursors.CharDoubleCursor
            astore 3 /* c */
        start local 3 // com.carrotsearch.hppc.cursors.CharDoubleCursor c
         3: .line 196
            aload 0 /* this */
            aload 3 /* c */
            getfield com.carrotsearch.hppc.cursors.CharDoubleCursor.key:C
            aload 3 /* c */
            getfield com.carrotsearch.hppc.cursors.CharDoubleCursor.value:D
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.put:(CD)D
            pop2
        end local 3 // com.carrotsearch.hppc.cursors.CharDoubleCursor c
         4: .line 195
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 198
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            iload 2 /* count */
            isub
            ireturn
        end local 2 // int count
        end local 1 // com.carrotsearch.hppc.CharDoubleAssociativeContainer container
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0       this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    6     1  container  Lcom/carrotsearch/hppc/CharDoubleAssociativeContainer;
            1    6     2      count  I
            3    4     3          c  Lcom/carrotsearch/hppc/cursors/CharDoubleCursor;
    MethodParameters:
           Name  Flags
      container  

  public int putAll(java.lang.Iterable<? extends com.carrotsearch.hppc.cursors.CharDoubleCursor>);
    descriptor: (Ljava/lang/Iterable;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // java.lang.Iterable iterable
         0: .line 206
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            istore 2 /* count */
        start local 2 // int count
         1: .line 207
            aload 1 /* iterable */
            invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
            astore 4
            goto 4
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap java.lang.Iterable int top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.carrotsearch.hppc.cursors.CharDoubleCursor
            astore 3 /* c */
        start local 3 // com.carrotsearch.hppc.cursors.CharDoubleCursor c
         3: .line 208
            aload 0 /* this */
            aload 3 /* c */
            getfield com.carrotsearch.hppc.cursors.CharDoubleCursor.key:C
            aload 3 /* c */
            getfield com.carrotsearch.hppc.cursors.CharDoubleCursor.value:D
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.put:(CD)D
            pop2
        end local 3 // com.carrotsearch.hppc.cursors.CharDoubleCursor c
         4: .line 207
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 210
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            iload 2 /* count */
            isub
            ireturn
        end local 2 // int count
        end local 1 // java.lang.Iterable iterable
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    6     1  iterable  Ljava/lang/Iterable<+Lcom/carrotsearch/hppc/cursors/CharDoubleCursor;>;
            1    6     2     count  I
            3    4     3         c  Lcom/carrotsearch/hppc/cursors/CharDoubleCursor;
    Signature: (Ljava/lang/Iterable<+Lcom/carrotsearch/hppc/cursors/CharDoubleCursor;>;)I
    MethodParameters:
          Name  Flags
      iterable  

  public boolean putIfAbsent(char, double);
    descriptor: (CD)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=3
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // char key
        start local 2 // double value
         0: .line 226
            aload 0 /* this */
            iload 1 /* key */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.indexOf:(C)I
            istore 4 /* keyIndex */
        start local 4 // int keyIndex
         1: .line 227
            aload 0 /* this */
            iload 4 /* keyIndex */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.indexExists:(I)Z
            ifne 4
         2: .line 228
            aload 0 /* this */
            iload 4 /* keyIndex */
            iload 1 /* key */
            dload 2 /* value */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.indexInsert:(ICD)V
         3: .line 229
            iconst_1
            ireturn
         4: .line 231
      StackMap locals: int
      StackMap stack:
            iconst_0
            ireturn
        end local 4 // int keyIndex
        end local 2 // double value
        end local 1 // char key
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0      this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    5     1       key  C
            0    5     2     value  D
            1    5     4  keyIndex  I
    MethodParameters:
       Name  Flags
      key    
      value  

  public double putOrAdd(char, double, double);
    descriptor: (CDD)D
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=7, args_size=4
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // char key
        start local 2 // double putValue
        start local 4 // double incrementValue
         0: .line 251
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            if_icmplt 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 253
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* key */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.indexOf:(C)I
            istore 6 /* keyIndex */
        start local 6 // int keyIndex
         2: .line 254
            aload 0 /* this */
            iload 6 /* keyIndex */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.indexExists:(I)Z
            ifeq 6
         3: .line 255
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 6 /* keyIndex */
            daload
            dload 4 /* incrementValue */
            dadd
            dstore 2 /* putValue */
         4: .line 256
            aload 0 /* this */
            iload 6 /* keyIndex */
            dload 2 /* putValue */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.indexReplace:(ID)D
            pop2
         5: .line 257
            goto 7
         6: .line 258
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            iload 6 /* keyIndex */
            iload 1 /* key */
            dload 2 /* putValue */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.indexInsert:(ICD)V
         7: .line 260
      StackMap locals:
      StackMap stack:
            dload 2 /* putValue */
            dreturn
        end local 6 // int keyIndex
        end local 4 // double incrementValue
        end local 2 // double putValue
        end local 1 // char key
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    8     0            this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    8     1             key  C
            0    8     2        putValue  D
            0    8     4  incrementValue  D
            2    8     6        keyIndex  I
    MethodParameters:
                Name  Flags
      key             
      putValue        
      incrementValue  

  public double addTo(char, double);
    descriptor: (CD)D
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=3
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // char key
        start local 2 // double incrementValue
         0: .line 276
            aload 0 /* this */
            iload 1 /* key */
            dload 2 /* incrementValue */
            dload 2 /* incrementValue */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.putOrAdd:(CDD)D
            dreturn
        end local 2 // double incrementValue
        end local 1 // char key
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    1     0            this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    1     1             key  C
            0    1     2  incrementValue  D
    MethodParameters:
                Name  Flags
      key             
      incrementValue  

  public double remove(char);
    descriptor: (C)D
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=8, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // char key
         0: .line 285
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 2 /* mask */
        start local 2 // int mask
         1: .line 286
            iload 1 /* key */
            ifne 6
         2: .line 287
            aload 0 /* this */
            iconst_0
            putfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
         3: .line 288
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 2 /* mask */
            iconst_1
            iadd
            daload
            dstore 3 /* previousValue */
        start local 3 // double previousValue
         4: .line 289
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 2 /* mask */
            iconst_1
            iadd
            dconst_0
            dastore
         5: .line 290
            dload 3 /* previousValue */
            dreturn
        end local 3 // double previousValue
         6: .line 292
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 3 /* keys */
        start local 3 // char[] keys
         7: .line 293
            aload 0 /* this */
            iload 1 /* key */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.hashKey:(C)I
            iload 2 /* mask */
            iand
            istore 4 /* slot */
        start local 4 // int slot
         8: .line 296
            goto 14
        start local 5 // char existing
         9: .line 297
      StackMap locals: char[] int int
      StackMap stack:
            iload 5 /* existing */
            iload 1 /* key */
            if_icmpne 13
        10: .line 298
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 4 /* slot */
            daload
            dstore 6 /* previousValue */
        start local 6 // double previousValue
        11: .line 299
            aload 0 /* this */
            iload 4 /* slot */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.shiftConflictingKeys:(I)V
        12: .line 300
            dload 6 /* previousValue */
            dreturn
        end local 6 // double previousValue
        13: .line 302
      StackMap locals:
      StackMap stack:
            iload 4 /* slot */
            iconst_1
            iadd
            iload 2 /* mask */
            iand
            istore 4 /* slot */
        end local 5 // char existing
        14: .line 296
      StackMap locals:
      StackMap stack:
            aload 3 /* keys */
            iload 4 /* slot */
            caload
            dup
            istore 5 /* existing */
        start local 5 // char existing
        15: ifne 9
        16: .line 305
            dconst_0
            dreturn
        end local 5 // char existing
        end local 4 // int slot
        end local 3 // char[] keys
        end local 2 // int mask
        end local 1 // char key
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   17     0           this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   17     1            key  C
            1   17     2           mask  I
            4    6     3  previousValue  D
            7   17     3           keys  [C
            8   17     4           slot  I
            9   14     5       existing  C
           15   17     5       existing  C
           11   13     6  previousValue  D
    MethodParameters:
      Name  Flags
      key   

  public int removeAll(com.carrotsearch.hppc.CharContainer);
    descriptor: (Lcom/carrotsearch/hppc/CharContainer;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=7, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // com.carrotsearch.hppc.CharContainer other
         0: .line 314
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            istore 2 /* before */
        start local 2 // int before
         1: .line 320
            aload 1 /* other */
            invokeinterface com.carrotsearch.hppc.CharContainer.size:()I
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            if_icmplt 18
         2: .line 321
            aload 1 /* other */
            instanceof com.carrotsearch.hppc.CharLookupContainer
            ifeq 18
         3: .line 322
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifeq 7
         4: .line 323
            aload 1 /* other */
            iconst_0
            invokeinterface com.carrotsearch.hppc.CharContainer.contains:(C)Z
            ifeq 7
         5: .line 324
            aload 0 /* this */
            iconst_0
            putfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
         6: .line 325
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            dconst_0
            dastore
         7: .line 329
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 3 /* keys */
        start local 3 // char[] keys
         8: .line 330
            iconst_0
            istore 4 /* slot */
        start local 4 // int slot
         9: aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 5 /* max */
        start local 5 // int max
        10: goto 16
        11: .line 332
      StackMap locals: char[] int int
      StackMap stack:
            aload 3 /* keys */
            iload 4 /* slot */
            caload
            dup
            istore 6 /* existing */
        start local 6 // char existing
        12: ifeq 15
            aload 1 /* other */
            iload 6 /* existing */
            invokeinterface com.carrotsearch.hppc.CharContainer.contains:(C)Z
            ifeq 15
        13: .line 334
            aload 0 /* this */
            iload 4 /* slot */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.shiftConflictingKeys:(I)V
        14: .line 335
            goto 16
        15: .line 336
      StackMap locals: int
      StackMap stack:
            iinc 4 /* slot */ 1
        end local 6 // char existing
        16: .line 330
      StackMap locals:
      StackMap stack:
            iload 4 /* slot */
            iload 5 /* max */
            if_icmple 11
        end local 5 // int max
        end local 4 // int slot
        end local 3 // char[] keys
        17: .line 339
            goto 22
        18: .line 340
      StackMap locals:
      StackMap stack:
            aload 1 /* other */
            invokeinterface com.carrotsearch.hppc.CharContainer.iterator:()Ljava/util/Iterator;
            astore 4
            goto 21
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap com.carrotsearch.hppc.CharContainer int top java.util.Iterator
      StackMap stack:
        19: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.carrotsearch.hppc.cursors.CharCursor
            astore 3 /* c */
        start local 3 // com.carrotsearch.hppc.cursors.CharCursor c
        20: .line 341
            aload 0 /* this */
            aload 3 /* c */
            getfield com.carrotsearch.hppc.cursors.CharCursor.value:C
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.remove:(C)D
            pop2
        end local 3 // com.carrotsearch.hppc.cursors.CharCursor c
        21: .line 340
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 19
        22: .line 345
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap com.carrotsearch.hppc.CharContainer int
      StackMap stack:
            iload 2 /* before */
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            isub
            ireturn
        end local 2 // int before
        end local 1 // com.carrotsearch.hppc.CharContainer other
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   23     0      this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   23     1     other  Lcom/carrotsearch/hppc/CharContainer;
            1   23     2    before  I
            8   17     3      keys  [C
            9   17     4      slot  I
           10   17     5       max  I
           12   16     6  existing  C
           20   21     3         c  Lcom/carrotsearch/hppc/cursors/CharCursor;
    MethodParameters:
       Name  Flags
      other  

  public int removeAll(com.carrotsearch.hppc.predicates.CharDoublePredicate);
    descriptor: (Lcom/carrotsearch/hppc/predicates/CharDoublePredicate;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=8, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // com.carrotsearch.hppc.predicates.CharDoublePredicate predicate
         0: .line 353
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            istore 2 /* before */
        start local 2 // int before
         1: .line 355
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 3 /* mask */
        start local 3 // int mask
         2: .line 357
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifeq 6
         3: .line 358
            aload 1 /* predicate */
            iconst_0
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 3 /* mask */
            iconst_1
            iadd
            daload
            invokeinterface com.carrotsearch.hppc.predicates.CharDoublePredicate.apply:(CD)Z
            ifeq 6
         4: .line 359
            aload 0 /* this */
            iconst_0
            putfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
         5: .line 360
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 3 /* mask */
            iconst_1
            iadd
            dconst_0
            dastore
         6: .line 364
      StackMap locals: int int
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 4 /* keys */
        start local 4 // char[] keys
         7: .line 365
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            astore 5 /* values */
        start local 5 // double[] values
         8: .line 366
            iconst_0
            istore 6 /* slot */
        start local 6 // int slot
         9: goto 16
        10: .line 368
      StackMap locals: char[] double[] int
      StackMap stack:
            aload 4 /* keys */
            iload 6 /* slot */
            caload
            dup
            istore 7 /* existing */
        start local 7 // char existing
        11: ifeq 15
        12: .line 369
            aload 1 /* predicate */
            iload 7 /* existing */
            aload 5 /* values */
            iload 6 /* slot */
            daload
            invokeinterface com.carrotsearch.hppc.predicates.CharDoublePredicate.apply:(CD)Z
            ifeq 15
        13: .line 371
            aload 0 /* this */
            iload 6 /* slot */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.shiftConflictingKeys:(I)V
        14: .line 372
            goto 16
        15: .line 373
      StackMap locals: int
      StackMap stack:
            iinc 6 /* slot */ 1
        end local 7 // char existing
        16: .line 366
      StackMap locals:
      StackMap stack:
            iload 6 /* slot */
            iload 3 /* mask */
            if_icmple 10
        end local 6 // int slot
        17: .line 377
            iload 2 /* before */
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            isub
            ireturn
        end local 5 // double[] values
        end local 4 // char[] keys
        end local 3 // int mask
        end local 2 // int before
        end local 1 // com.carrotsearch.hppc.predicates.CharDoublePredicate predicate
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   18     0       this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   18     1  predicate  Lcom/carrotsearch/hppc/predicates/CharDoublePredicate;
            1   18     2     before  I
            2   18     3       mask  I
            7   18     4       keys  [C
            8   18     5     values  [D
            9   17     6       slot  I
           11   16     7   existing  C
    MethodParameters:
           Name  Flags
      predicate  

  public int removeAll(com.carrotsearch.hppc.predicates.CharPredicate);
    descriptor: (Lcom/carrotsearch/hppc/predicates/CharPredicate;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=7, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // com.carrotsearch.hppc.predicates.CharPredicate predicate
         0: .line 385
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            istore 2 /* before */
        start local 2 // int before
         1: .line 387
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifeq 5
         2: .line 388
            aload 1 /* predicate */
            iconst_0
            invokeinterface com.carrotsearch.hppc.predicates.CharPredicate.apply:(C)Z
            ifeq 5
         3: .line 389
            aload 0 /* this */
            iconst_0
            putfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
         4: .line 390
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            dconst_0
            dastore
         5: .line 394
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 3 /* keys */
        start local 3 // char[] keys
         6: .line 395
            iconst_0
            istore 4 /* slot */
        start local 4 // int slot
         7: aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 5 /* max */
        start local 5 // int max
         8: goto 15
         9: .line 397
      StackMap locals: char[] int int
      StackMap stack:
            aload 3 /* keys */
            iload 4 /* slot */
            caload
            dup
            istore 6 /* existing */
        start local 6 // char existing
        10: ifeq 14
        11: .line 398
            aload 1 /* predicate */
            iload 6 /* existing */
            invokeinterface com.carrotsearch.hppc.predicates.CharPredicate.apply:(C)Z
            ifeq 14
        12: .line 400
            aload 0 /* this */
            iload 4 /* slot */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.shiftConflictingKeys:(I)V
        13: .line 401
            goto 15
        14: .line 402
      StackMap locals: int
      StackMap stack:
            iinc 4 /* slot */ 1
        end local 6 // char existing
        15: .line 395
      StackMap locals:
      StackMap stack:
            iload 4 /* slot */
            iload 5 /* max */
            if_icmple 9
        end local 5 // int max
        end local 4 // int slot
        16: .line 406
            iload 2 /* before */
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            isub
            ireturn
        end local 3 // char[] keys
        end local 2 // int before
        end local 1 // com.carrotsearch.hppc.predicates.CharPredicate predicate
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   17     0       this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   17     1  predicate  Lcom/carrotsearch/hppc/predicates/CharPredicate;
            1   17     2     before  I
            6   17     3       keys  [C
            7   16     4       slot  I
            8   16     5        max  I
           10   15     6   existing  C
    MethodParameters:
           Name  Flags
      predicate  

  public double get(char);
    descriptor: (C)D
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=6, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // char key
         0: .line 414
            iload 1 /* key */
            ifne 4
         1: .line 415
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifeq 2
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            daload
            goto 3
      StackMap locals:
      StackMap stack:
         2: dconst_0
      StackMap locals:
      StackMap stack: double
         3: dreturn
         4: .line 417
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 2 /* keys */
        start local 2 // char[] keys
         5: .line 418
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 3 /* mask */
        start local 3 // int mask
         6: .line 419
            aload 0 /* this */
            iload 1 /* key */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.hashKey:(C)I
            iload 3 /* mask */
            iand
            istore 4 /* slot */
        start local 4 // int slot
         7: .line 422
            goto 11
        start local 5 // char existing
         8: .line 423
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap int char[] int int int
      StackMap stack:
            iload 5 /* existing */
            iload 1 /* key */
            if_icmpne 10
         9: .line 424
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 4 /* slot */
            daload
            dreturn
        10: .line 426
      StackMap locals:
      StackMap stack:
            iload 4 /* slot */
            iconst_1
            iadd
            iload 3 /* mask */
            iand
            istore 4 /* slot */
        end local 5 // char existing
        11: .line 422
      StackMap locals:
      StackMap stack:
            aload 2 /* keys */
            iload 4 /* slot */
            caload
            dup
            istore 5 /* existing */
        start local 5 // char existing
        12: ifne 8
        13: .line 429
            dconst_0
            dreturn
        end local 5 // char existing
        end local 4 // int slot
        end local 3 // int mask
        end local 2 // char[] keys
        end local 1 // char key
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   14     0      this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   14     1       key  C
            5   14     2      keys  [C
            6   14     3      mask  I
            7   14     4      slot  I
            8   11     5  existing  C
           12   14     5  existing  C
    MethodParameters:
      Name  Flags
      key   

  public double getOrDefault(char, double);
    descriptor: (CD)D
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=8, args_size=3
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // char key
        start local 2 // double defaultValue
         0: .line 438
            iload 1 /* key */
            ifne 4
         1: .line 439
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifeq 2
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            daload
            goto 3
      StackMap locals:
      StackMap stack:
         2: dload 2 /* defaultValue */
      StackMap locals:
      StackMap stack: double
         3: dreturn
         4: .line 441
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 4 /* keys */
        start local 4 // char[] keys
         5: .line 442
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 5 /* mask */
        start local 5 // int mask
         6: .line 443
            aload 0 /* this */
            iload 1 /* key */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.hashKey:(C)I
            iload 5 /* mask */
            iand
            istore 6 /* slot */
        start local 6 // int slot
         7: .line 446
            goto 11
        start local 7 // char existing
         8: .line 447
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap int double char[] int int int
      StackMap stack:
            iload 7 /* existing */
            iload 1 /* key */
            if_icmpne 10
         9: .line 448
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 6 /* slot */
            daload
            dreturn
        10: .line 450
      StackMap locals:
      StackMap stack:
            iload 6 /* slot */
            iconst_1
            iadd
            iload 5 /* mask */
            iand
            istore 6 /* slot */
        end local 7 // char existing
        11: .line 446
      StackMap locals:
      StackMap stack:
            aload 4 /* keys */
            iload 6 /* slot */
            caload
            dup
            istore 7 /* existing */
        start local 7 // char existing
        12: ifne 8
        13: .line 453
            dload 2 /* defaultValue */
            dreturn
        end local 7 // char existing
        end local 6 // int slot
        end local 5 // int mask
        end local 4 // char[] keys
        end local 2 // double defaultValue
        end local 1 // char key
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   14     0          this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   14     1           key  C
            0   14     2  defaultValue  D
            5   14     4          keys  [C
            6   14     5          mask  I
            7   14     6          slot  I
            8   11     7      existing  C
           12   14     7      existing  C
    MethodParameters:
              Name  Flags
      key           
      defaultValue  

  public boolean containsKey(char);
    descriptor: (C)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=6, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // char key
         0: .line 462
            iload 1 /* key */
            ifne 2
         1: .line 463
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ireturn
         2: .line 465
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 2 /* keys */
        start local 2 // char[] keys
         3: .line 466
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 3 /* mask */
        start local 3 // int mask
         4: .line 467
            aload 0 /* this */
            iload 1 /* key */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.hashKey:(C)I
            iload 3 /* mask */
            iand
            istore 4 /* slot */
        start local 4 // int slot
         5: .line 470
            goto 9
        start local 5 // char existing
         6: .line 471
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap int char[] int int int
      StackMap stack:
            iload 5 /* existing */
            iload 1 /* key */
            if_icmpne 8
         7: .line 472
            iconst_1
            ireturn
         8: .line 474
      StackMap locals:
      StackMap stack:
            iload 4 /* slot */
            iconst_1
            iadd
            iload 3 /* mask */
            iand
            istore 4 /* slot */
        end local 5 // char existing
         9: .line 470
      StackMap locals:
      StackMap stack:
            aload 2 /* keys */
            iload 4 /* slot */
            caload
            dup
            istore 5 /* existing */
        start local 5 // char existing
        10: ifne 6
        11: .line 477
            iconst_0
            ireturn
        end local 5 // char existing
        end local 4 // int slot
        end local 3 // int mask
        end local 2 // char[] keys
        end local 1 // char key
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   12     0      this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   12     1       key  C
            3   12     2      keys  [C
            4   12     3      mask  I
            5   12     4      slot  I
            6    9     5  existing  C
           10   12     5  existing  C
    MethodParameters:
      Name  Flags
      key   

  public int indexOf(char);
    descriptor: (C)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=6, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // char key
         0: .line 486
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 2 /* mask */
        start local 2 // int mask
         1: .line 487
            iload 1 /* key */
            ifne 5
         2: .line 488
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifeq 3
            iload 2 /* mask */
            iconst_1
            iadd
            goto 4
      StackMap locals: int
      StackMap stack:
         3: iload 2 /* mask */
            iconst_1
            iadd
            iconst_m1
            ixor
      StackMap locals:
      StackMap stack: int
         4: ireturn
         5: .line 490
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 3 /* keys */
        start local 3 // char[] keys
         6: .line 491
            aload 0 /* this */
            iload 1 /* key */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.hashKey:(C)I
            iload 2 /* mask */
            iand
            istore 4 /* slot */
        start local 4 // int slot
         7: .line 494
            goto 11
        start local 5 // char existing
         8: .line 495
      StackMap locals: char[] int int
      StackMap stack:
            iload 5 /* existing */
            iload 1 /* key */
            if_icmpne 10
         9: .line 496
            iload 4 /* slot */
            ireturn
        10: .line 498
      StackMap locals:
      StackMap stack:
            iload 4 /* slot */
            iconst_1
            iadd
            iload 2 /* mask */
            iand
            istore 4 /* slot */
        end local 5 // char existing
        11: .line 494
      StackMap locals:
      StackMap stack:
            aload 3 /* keys */
            iload 4 /* slot */
            caload
            dup
            istore 5 /* existing */
        start local 5 // char existing
        12: ifne 8
        13: .line 501
            iload 4 /* slot */
            iconst_m1
            ixor
            ireturn
        end local 5 // char existing
        end local 4 // int slot
        end local 3 // char[] keys
        end local 2 // int mask
        end local 1 // char key
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   14     0      this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   14     1       key  C
            1   14     2      mask  I
            6   14     3      keys  [C
            7   14     4      slot  I
            8   11     5  existing  C
           12   14     5  existing  C
    MethodParameters:
      Name  Flags
      key   

  public boolean indexExists(int);
    descriptor: (I)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // int index
         0: .line 510
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 4
            iload 1 /* index */
            iflt 4
         1: .line 511
            iload 1 /* index */
            iflt 2
            iload 1 /* index */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            if_icmple 4
         2: .line 512
      StackMap locals:
      StackMap stack:
            iload 1 /* index */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            if_icmpne 3
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifne 4
      StackMap locals:
      StackMap stack:
         3: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         4: .line 514
      StackMap locals:
      StackMap stack:
            iload 1 /* index */
            iflt 5
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         5: iconst_0
            ireturn
        end local 1 // int index
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    6     0   this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    6     1  index  I
    MethodParameters:
       Name  Flags
      index  

  public double indexGet(int);
    descriptor: (I)D
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // int index
         0: .line 522
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 1
            iload 1 /* index */
            ifge 1
            new java.lang.AssertionError
            dup
            ldc "The index must point at an existing key."
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 523
      StackMap locals:
      StackMap stack:
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 4
            iload 1 /* index */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            if_icmple 4
         2: .line 524
            iload 1 /* index */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            if_icmpne 3
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifne 4
      StackMap locals:
      StackMap stack:
         3: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         4: .line 526
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 1 /* index */
            daload
            dreturn
        end local 1 // int index
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    5     1  index  I
    MethodParameters:
       Name  Flags
      index  

  public double indexReplace(int, double);
    descriptor: (ID)D
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // int index
        start local 2 // double newValue
         0: .line 534
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 1
            iload 1 /* index */
            ifge 1
            new java.lang.AssertionError
            dup
            ldc "The index must point at an existing key."
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 535
      StackMap locals:
      StackMap stack:
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 4
            iload 1 /* index */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            if_icmple 4
         2: .line 536
            iload 1 /* index */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            if_icmpne 3
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifne 4
      StackMap locals:
      StackMap stack:
         3: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         4: .line 538
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 1 /* index */
            daload
            dstore 4 /* previousValue */
        start local 4 // double previousValue
         5: .line 539
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 1 /* index */
            dload 2 /* newValue */
            dastore
         6: .line 540
            dload 4 /* previousValue */
            dreturn
        end local 4 // double previousValue
        end local 2 // double newValue
        end local 1 // int index
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    7     0           this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    7     1          index  I
            0    7     2       newValue  D
            5    7     4  previousValue  D
    MethodParameters:
          Name  Flags
      index     
      newValue  

  public void indexInsert(int, char, double);
    descriptor: (ICD)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // int index
        start local 2 // char key
        start local 3 // double value
         0: .line 548
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 1
            iload 1 /* index */
            iflt 1
            new java.lang.AssertionError
            dup
            ldc "The index must not point at an existing key."
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 550
      StackMap locals:
      StackMap stack:
            iload 1 /* index */
            iconst_m1
            ixor
            istore 1 /* index */
         2: .line 551
            iload 2 /* key */
            ifne 7
         3: .line 552
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 4
            iload 1 /* index */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            if_icmpeq 4
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         4: .line 553
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 1 /* index */
            dload 3 /* value */
            dastore
         5: .line 554
            aload 0 /* this */
            iconst_1
            putfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
         6: .line 555
            goto 14
         7: .line 556
      StackMap locals:
      StackMap stack:
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 8
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            iload 1 /* index */
            caload
            ifeq 8
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         8: .line 558
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.resizeAt:I
            if_icmpne 11
         9: .line 559
            aload 0 /* this */
            iload 1 /* index */
            iload 2 /* key */
            dload 3 /* value */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.allocateThenInsertThenRehash:(ICD)V
        10: .line 560
            goto 13
        11: .line 561
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            iload 1 /* index */
            iload 2 /* key */
            castore
        12: .line 562
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            iload 1 /* index */
            dload 3 /* value */
            dastore
        13: .line 565
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
            iconst_1
            iadd
            putfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
        14: .line 567
      StackMap locals:
      StackMap stack:
            return
        end local 3 // double value
        end local 2 // char key
        end local 1 // int index
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   15     0   this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   15     1  index  I
            0   15     2    key  C
            0   15     3  value  D
    MethodParameters:
       Name  Flags
      index  
      key    
      value  

  public void clear();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
         0: .line 574
            aload 0 /* this */
            iconst_0
            putfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
         1: .line 575
            aload 0 /* this */
            iconst_0
            putfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
         2: .line 577
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            iconst_0
            invokestatic java.util.Arrays.fill:([CC)V
         3: .line 580
            return
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lcom/carrotsearch/hppc/CharDoubleHashMap;

  public void release();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
         0: .line 587
            aload 0 /* this */
            iconst_0
            putfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
         1: .line 588
            aload 0 /* this */
            iconst_0
            putfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
         2: .line 590
            aload 0 /* this */
            aconst_null
            putfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
         3: .line 591
            aload 0 /* this */
            aconst_null
            putfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
         4: .line 592
            aload 0 /* this */
            iconst_4
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.ensureCapacity:(I)V
         5: .line 593
            return
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lcom/carrotsearch/hppc/CharDoubleHashMap;

  public int size();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
         0: .line 600
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifeq 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack: int
         1: iconst_0
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap
      StackMap stack: int int
         2: iadd
            ireturn
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/carrotsearch/hppc/CharDoubleHashMap;

  public boolean isEmpty();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
         0: .line 607
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            ifne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/carrotsearch/hppc/CharDoubleHashMap;

  public int hashCode();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
         0: .line 615
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifeq 1
            ldc -559038737
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: istore 1 /* h */
        start local 1 // int h
         3: .line 616
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.iterator:()Ljava/util/Iterator;
            astore 3
            goto 8
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap int top java.util.Iterator
      StackMap stack:
         4: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.carrotsearch.hppc.cursors.CharDoubleCursor
            astore 2 /* c */
        start local 2 // com.carrotsearch.hppc.cursors.CharDoubleCursor c
         5: .line 617
            iload 1 /* h */
            aload 2 /* c */
            getfield com.carrotsearch.hppc.cursors.CharDoubleCursor.key:C
            invokestatic com.carrotsearch.hppc.BitMixer.mix:(C)I
         6: .line 618
            aload 2 /* c */
            getfield com.carrotsearch.hppc.cursors.CharDoubleCursor.value:D
            invokestatic com.carrotsearch.hppc.BitMixer.mix:(D)I
         7: .line 617
            iadd
            iadd
            istore 1 /* h */
        end local 2 // com.carrotsearch.hppc.cursors.CharDoubleCursor c
         8: .line 616
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
         9: .line 620
            iload 1 /* h */
            ireturn
        end local 1 // int h
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            3   10     1     h  I
            5    8     2     c  Lcom/carrotsearch/hppc/cursors/CharDoubleCursor;

  public boolean equals(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // java.lang.Object obj
         0: .line 628
            aload 1 /* obj */
            ifnull 4
         1: .line 629
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            aload 1 /* obj */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            if_acmpne 4
         2: .line 630
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            aload 1 /* obj */
            invokevirtual java.lang.Class.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast com.carrotsearch.hppc.CharDoubleHashMap
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.equalElements:(Lcom/carrotsearch/hppc/CharDoubleHashMap;)Z
            ifeq 4
         3: .line 628
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         4: iconst_0
            ireturn
        end local 1 // java.lang.Object obj
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    5     1   obj  Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      obj   

  protected boolean equalElements(com.carrotsearch.hppc.CharDoubleHashMap);
    descriptor: (Lcom/carrotsearch/hppc/CharDoubleHashMap;)Z
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=5, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // com.carrotsearch.hppc.CharDoubleHashMap other
         0: .line 637
            aload 1 /* other */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            if_icmpeq 2
         1: .line 638
            iconst_0
            ireturn
         2: .line 641
      StackMap locals:
      StackMap stack:
            aload 1 /* other */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.iterator:()Ljava/util/Iterator;
            astore 3
            goto 8
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap com.carrotsearch.hppc.CharDoubleHashMap top java.util.Iterator
      StackMap stack:
         3: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.carrotsearch.hppc.cursors.CharDoubleCursor
            astore 2 /* c */
        start local 2 // com.carrotsearch.hppc.cursors.CharDoubleCursor c
         4: .line 642
            aload 2 /* c */
            getfield com.carrotsearch.hppc.cursors.CharDoubleCursor.key:C
            istore 4 /* key */
        start local 4 // char key
         5: .line 643
            aload 0 /* this */
            iload 4 /* key */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.containsKey:(C)Z
            ifeq 7
         6: .line 644
            aload 0 /* this */
            iload 4 /* key */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.get:(C)D
            invokestatic java.lang.Double.doubleToLongBits:(D)J
            aload 2 /* c */
            getfield com.carrotsearch.hppc.cursors.CharDoubleCursor.value:D
            invokestatic java.lang.Double.doubleToLongBits:(D)J
            lcmp
            ifeq 8
         7: .line 645
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap com.carrotsearch.hppc.CharDoubleHashMap com.carrotsearch.hppc.cursors.CharDoubleCursor java.util.Iterator int
      StackMap stack:
            iconst_0
            ireturn
        end local 4 // char key
        end local 2 // com.carrotsearch.hppc.cursors.CharDoubleCursor c
         8: .line 641
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap com.carrotsearch.hppc.CharDoubleHashMap top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         9: .line 649
            iconst_1
            ireturn
        end local 1 // com.carrotsearch.hppc.CharDoubleHashMap other
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   10     0   this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   10     1  other  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            4    8     2      c  Lcom/carrotsearch/hppc/cursors/CharDoubleCursor;
            5    8     4    key  C
    MethodParameters:
       Name  Flags
      other  

  public void ensureCapacity(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // int expectedElements
         0: .line 660
            iload 1 /* expectedElements */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.resizeAt:I
            if_icmpgt 1
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            ifnonnull 6
         1: .line 661
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 2 /* prevKeys */
        start local 2 // char[] prevKeys
         2: .line 662
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            astore 3 /* prevValues */
        start local 3 // double[] prevValues
         3: .line 663
            aload 0 /* this */
            iload 1 /* expectedElements */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.loadFactor:D
            invokestatic com.carrotsearch.hppc.HashContainers.minBufferSize:(ID)I
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.allocateBuffers:(I)V
         4: .line 664
            aload 2 /* prevKeys */
            ifnull 6
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.isEmpty:()Z
            ifne 6
         5: .line 665
            aload 0 /* this */
            aload 2 /* prevKeys */
            aload 3 /* prevValues */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.rehash:([C[D)V
        end local 3 // double[] prevValues
        end local 2 // char[] prevKeys
         6: .line 668
      StackMap locals:
      StackMap stack:
            return
        end local 1 // int expectedElements
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    7     0              this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    7     1  expectedElements  I
            2    6     2          prevKeys  [C
            3    6     3        prevValues  [D
    MethodParameters:
                  Name  Flags
      expectedElements  

  public java.util.Iterator<com.carrotsearch.hppc.cursors.CharDoubleCursor> iterator();
    descriptor: ()Ljava/util/Iterator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
         0: .line 713
            new com.carrotsearch.hppc.CharDoubleHashMap$EntryIterator
            dup
            aload 0 /* this */
            invokespecial com.carrotsearch.hppc.CharDoubleHashMap$EntryIterator.<init>:(Lcom/carrotsearch/hppc/CharDoubleHashMap;)V
            areturn
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
    Signature: ()Ljava/util/Iterator<Lcom/carrotsearch/hppc/cursors/CharDoubleCursor;>;

  public <T extends com.carrotsearch.hppc.procedures.CharDoubleProcedure> T forEach();
    descriptor: (Lcom/carrotsearch/hppc/procedures/CharDoubleProcedure;)Lcom/carrotsearch/hppc/procedures/CharDoubleProcedure;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // com.carrotsearch.hppc.procedures.CharDoubleProcedure procedure
         0: .line 721
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 2 /* keys */
        start local 2 // char[] keys
         1: .line 722
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            astore 3 /* values */
        start local 3 // double[] values
         2: .line 724
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifeq 4
         3: .line 725
            aload 1 /* procedure */
            iconst_0
            aload 3 /* values */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            daload
            invokeinterface com.carrotsearch.hppc.procedures.CharDoubleProcedure.apply:(CD)V
         4: .line 728
      StackMap locals: char[] double[]
      StackMap stack:
            iconst_0
            istore 4 /* slot */
        start local 4 // int slot
         5: aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 5 /* max */
        start local 5 // int max
         6: goto 10
         7: .line 729
      StackMap locals: int int
      StackMap stack:
            aload 2 /* keys */
            iload 4 /* slot */
            caload
            ifeq 9
         8: .line 730
            aload 1 /* procedure */
            aload 2 /* keys */
            iload 4 /* slot */
            caload
            aload 3 /* values */
            iload 4 /* slot */
            daload
            invokeinterface com.carrotsearch.hppc.procedures.CharDoubleProcedure.apply:(CD)V
         9: .line 728
      StackMap locals:
      StackMap stack:
            iinc 4 /* slot */ 1
      StackMap locals:
      StackMap stack:
        10: iload 4 /* slot */
            iload 5 /* max */
            if_icmple 7
        end local 5 // int max
        end local 4 // int slot
        11: .line 734
            aload 1 /* procedure */
            areturn
        end local 3 // double[] values
        end local 2 // char[] keys
        end local 1 // com.carrotsearch.hppc.procedures.CharDoubleProcedure procedure
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   12     0       this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   12     1  procedure  TT;
            1   12     2       keys  [C
            2   12     3     values  [D
            5   11     4       slot  I
            6   11     5        max  I
    Signature: <T::Lcom/carrotsearch/hppc/procedures/CharDoubleProcedure;>(TT;)TT;
    MethodParameters:
           Name  Flags
      procedure  

  public <T extends com.carrotsearch.hppc.predicates.CharDoublePredicate> T forEach();
    descriptor: (Lcom/carrotsearch/hppc/predicates/CharDoublePredicate;)Lcom/carrotsearch/hppc/predicates/CharDoublePredicate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // com.carrotsearch.hppc.predicates.CharDoublePredicate predicate
         0: .line 742
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 2 /* keys */
        start local 2 // char[] keys
         1: .line 743
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            astore 3 /* values */
        start local 3 // double[] values
         2: .line 745
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            ifeq 5
         3: .line 746
            aload 1 /* predicate */
            iconst_0
            aload 3 /* values */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            daload
            invokeinterface com.carrotsearch.hppc.predicates.CharDoublePredicate.apply:(CD)Z
            ifne 5
         4: .line 747
            aload 1 /* predicate */
            areturn
         5: .line 751
      StackMap locals: char[] double[]
      StackMap stack:
            iconst_0
            istore 4 /* slot */
        start local 4 // int slot
         6: aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 5 /* max */
        start local 5 // int max
         7: goto 12
         8: .line 752
      StackMap locals: int int
      StackMap stack:
            aload 2 /* keys */
            iload 4 /* slot */
            caload
            ifeq 11
         9: .line 753
            aload 1 /* predicate */
            aload 2 /* keys */
            iload 4 /* slot */
            caload
            aload 3 /* values */
            iload 4 /* slot */
            daload
            invokeinterface com.carrotsearch.hppc.predicates.CharDoublePredicate.apply:(CD)Z
            ifne 11
        10: .line 754
            goto 13
        11: .line 751
      StackMap locals:
      StackMap stack:
            iinc 4 /* slot */ 1
      StackMap locals:
      StackMap stack:
        12: iload 4 /* slot */
            iload 5 /* max */
            if_icmple 8
        end local 5 // int max
        end local 4 // int slot
        13: .line 759
      StackMap locals:
      StackMap stack:
            aload 1 /* predicate */
            areturn
        end local 3 // double[] values
        end local 2 // char[] keys
        end local 1 // com.carrotsearch.hppc.predicates.CharDoublePredicate predicate
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   14     0       this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   14     1  predicate  TT;
            1   14     2       keys  [C
            2   14     3     values  [D
            6   13     4       slot  I
            7   13     5        max  I
    Signature: <T::Lcom/carrotsearch/hppc/predicates/CharDoublePredicate;>(TT;)TT;
    MethodParameters:
           Name  Flags
      predicate  

  public com.carrotsearch.hppc.CharDoubleHashMap$KeysContainer keys();
    descriptor: ()Lcom/carrotsearch/hppc/CharDoubleHashMap$KeysContainer;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
         0: .line 767
            new com.carrotsearch.hppc.CharDoubleHashMap$KeysContainer
            dup
            aload 0 /* this */
            invokespecial com.carrotsearch.hppc.CharDoubleHashMap$KeysContainer.<init>:(Lcom/carrotsearch/hppc/CharDoubleHashMap;)V
            areturn
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/carrotsearch/hppc/CharDoubleHashMap;

  public com.carrotsearch.hppc.DoubleCollection values();
    descriptor: ()Lcom/carrotsearch/hppc/DoubleCollection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
         0: .line 889
            new com.carrotsearch.hppc.CharDoubleHashMap$ValuesContainer
            dup
            aload 0 /* this */
            invokespecial com.carrotsearch.hppc.CharDoubleHashMap$ValuesContainer.<init>:(Lcom/carrotsearch/hppc/CharDoubleHashMap;)V
            areturn
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/carrotsearch/hppc/CharDoubleHashMap;

  public com.carrotsearch.hppc.CharDoubleHashMap clone();
    descriptor: ()Lcom/carrotsearch/hppc/CharDoubleHashMap;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
         0: .line 1014
            aload 0 /* this */
            invokespecial java.lang.Object.clone:()Ljava/lang/Object;
            checkcast com.carrotsearch.hppc.CharDoubleHashMap
            astore 1 /* cloned */
        start local 1 // com.carrotsearch.hppc.CharDoubleHashMap cloned
         1: .line 1015
            aload 1 /* cloned */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            invokevirtual char[].clone:()Ljava/lang/Object;
            checkcast char[]
            putfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
         2: .line 1016
            aload 1 /* cloned */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            invokevirtual double[].clone:()Ljava/lang/Object;
            checkcast double[]
            putfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
         3: .line 1017
            aload 1 /* cloned */
            aload 1 /* cloned */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
            putfield com.carrotsearch.hppc.CharDoubleHashMap.hasEmptyKey:Z
         4: .line 1018
            aload 1 /* cloned */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.orderMixer:Lcom/carrotsearch/hppc/HashOrderMixingStrategy;
            invokeinterface com.carrotsearch.hppc.HashOrderMixingStrategy.clone:()Lcom/carrotsearch/hppc/HashOrderMixingStrategy;
            putfield com.carrotsearch.hppc.CharDoubleHashMap.orderMixer:Lcom/carrotsearch/hppc/HashOrderMixingStrategy;
         5: .line 1019
            aload 1 /* cloned */
         6: areturn
        end local 1 // com.carrotsearch.hppc.CharDoubleHashMap cloned
         7: .line 1020
      StackMap locals:
      StackMap stack: java.lang.CloneNotSupportedException
            astore 1 /* e */
        start local 1 // java.lang.CloneNotSupportedException e
         8: .line 1021
            new java.lang.RuntimeException
            dup
            aload 1 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.lang.CloneNotSupportedException e
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    9     0    this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            1    7     1  cloned  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            8    9     1       e  Ljava/lang/CloneNotSupportedException;
      Exception table:
        from    to  target  type
           0     6       7  Class java.lang.CloneNotSupportedException

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=1
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
         0: .line 1030
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 1 /* buffer */
        start local 1 // java.lang.StringBuilder buffer
         1: .line 1031
            aload 1 /* buffer */
            ldc "["
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         2: .line 1033
            iconst_1
            istore 2 /* first */
        start local 2 // boolean first
         3: .line 1034
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.iterator:()Ljava/util/Iterator;
            astore 4
            goto 11
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap java.lang.StringBuilder int top java.util.Iterator
      StackMap stack:
         4: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.carrotsearch.hppc.cursors.CharDoubleCursor
            astore 3 /* cursor */
        start local 3 // com.carrotsearch.hppc.cursors.CharDoubleCursor cursor
         5: .line 1035
            iload 2 /* first */
            ifne 7
         6: .line 1036
            aload 1 /* buffer */
            ldc ", "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         7: .line 1038
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap java.lang.StringBuilder int com.carrotsearch.hppc.cursors.CharDoubleCursor java.util.Iterator
      StackMap stack:
            aload 1 /* buffer */
            aload 3 /* cursor */
            getfield com.carrotsearch.hppc.cursors.CharDoubleCursor.key:C
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         8: .line 1039
            aload 1 /* buffer */
            ldc "=>"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         9: .line 1040
            aload 1 /* buffer */
            aload 3 /* cursor */
            getfield com.carrotsearch.hppc.cursors.CharDoubleCursor.value:D
            invokevirtual java.lang.StringBuilder.append:(D)Ljava/lang/StringBuilder;
            pop
        10: .line 1041
            iconst_0
            istore 2 /* first */
        end local 3 // com.carrotsearch.hppc.cursors.CharDoubleCursor cursor
        11: .line 1034
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap java.lang.StringBuilder int top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        12: .line 1043
            aload 1 /* buffer */
            ldc "]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        13: .line 1044
            aload 1 /* buffer */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 2 // boolean first
        end local 1 // java.lang.StringBuilder buffer
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   14     0    this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            1   14     1  buffer  Ljava/lang/StringBuilder;
            3   14     2   first  Z
            5   11     3  cursor  Lcom/carrotsearch/hppc/cursors/CharDoubleCursor;

  public java.lang.String visualizeKeyDistribution(int);
    descriptor: (I)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // int characters
         0: .line 1049
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iload 1 /* characters */
            invokestatic com.carrotsearch.hppc.CharBufferVisualizer.visualizeKeyDistribution:([CII)Ljava/lang/String;
            areturn
        end local 1 // int characters
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    1     1  characters  I
    MethodParameters:
            Name  Flags
      characters  

  public static com.carrotsearch.hppc.CharDoubleHashMap from(char[], double[]);
    descriptor: ([C[D)Lcom/carrotsearch/hppc/CharDoubleHashMap;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // char[] keys
        start local 1 // double[] values
         0: .line 1056
            aload 0 /* keys */
            arraylength
            aload 1 /* values */
            arraylength
            if_icmpeq 2
         1: .line 1057
            new java.lang.IllegalArgumentException
            dup
            ldc "Arrays of keys and values must have an identical length."
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 1060
      StackMap locals:
      StackMap stack:
            new com.carrotsearch.hppc.CharDoubleHashMap
            dup
            aload 0 /* keys */
            arraylength
            invokespecial com.carrotsearch.hppc.CharDoubleHashMap.<init>:(I)V
            astore 2 /* map */
        start local 2 // com.carrotsearch.hppc.CharDoubleHashMap map
         3: .line 1061
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         4: goto 7
         5: .line 1062
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap int
      StackMap stack:
            aload 2 /* map */
            aload 0 /* keys */
            iload 3 /* i */
            caload
            aload 1 /* values */
            iload 3 /* i */
            daload
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.put:(CD)D
            pop2
         6: .line 1061
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
         7: iload 3 /* i */
            aload 0 /* keys */
            arraylength
            if_icmplt 5
        end local 3 // int i
         8: .line 1065
            aload 2 /* map */
            areturn
        end local 2 // com.carrotsearch.hppc.CharDoubleHashMap map
        end local 1 // double[] values
        end local 0 // char[] keys
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    9     0    keys  [C
            0    9     1  values  [D
            3    9     2     map  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            4    8     3       i  I
    MethodParameters:
        Name  Flags
      keys    
      values  

  protected int hashKey(char);
    descriptor: (C)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // char key
         0: .line 1081
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 1
            iload 1 /* key */
            ifne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 1082
      StackMap locals:
      StackMap stack:
            iload 1 /* key */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keyMixer:I
            invokestatic com.carrotsearch.hppc.BitMixer.mix:(CI)I
            ireturn
        end local 1 // char key
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    2     1   key  C
    MethodParameters:
      Name  Flags
      key   

  protected double verifyLoadFactor(double);
    descriptor: (D)D
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=3, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // double loadFactor
         0: .line 1090
            dload 1 /* loadFactor */
            ldc 0.009999999776482582
            ldc 0.9900000095367432
            invokestatic com.carrotsearch.hppc.HashContainers.checkLoadFactor:(DDD)V
         1: .line 1091
            dload 1 /* loadFactor */
            dreturn
        end local 1 // double loadFactor
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0    2     1  loadFactor  D
    MethodParameters:
            Name  Flags
      loadFactor  

  protected void rehash(char[], double[]);
    descriptor: ([C[D)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=9, args_size=3
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // char[] fromKeys
        start local 2 // double[] fromValues
         0: .line 1098
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 3
            aload 1 /* fromKeys */
            arraylength
            aload 2 /* fromValues */
            arraylength
            if_icmpne 2
         1: .line 1099
            aload 1 /* fromKeys */
            arraylength
            iconst_1
            isub
            invokestatic com.carrotsearch.hppc.HashContainers.checkPowerOfTwo:(I)Z
            ifne 3
      StackMap locals:
      StackMap stack:
         2: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         3: .line 1102
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 3 /* keys */
        start local 3 // char[] keys
         4: .line 1103
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            astore 4 /* values */
        start local 4 // double[] values
         5: .line 1104
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 5 /* mask */
        start local 5 // int mask
         6: .line 1108
            aload 1 /* fromKeys */
            arraylength
            iconst_1
            isub
            istore 7 /* from */
        start local 7 // int from
         7: .line 1109
            aload 3 /* keys */
            aload 3 /* keys */
            arraylength
            iconst_1
            isub
            aload 1 /* fromKeys */
            iload 7 /* from */
            caload
            castore
         8: .line 1110
            aload 4 /* values */
            aload 4 /* values */
            arraylength
            iconst_1
            isub
            aload 2 /* fromValues */
            iload 7 /* from */
            daload
            dastore
         9: .line 1111
            goto 18
        10: .line 1112
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap char[] double[] char[] double[] int top int
      StackMap stack:
            aload 1 /* fromKeys */
            iload 7 /* from */
            caload
            dup
            istore 6 /* existing */
        start local 6 // char existing
        11: ifeq 18
        12: .line 1113
            aload 0 /* this */
            iload 6 /* existing */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.hashKey:(C)I
            iload 5 /* mask */
            iand
            istore 8 /* slot */
        start local 8 // int slot
        13: .line 1114
            goto 15
        14: .line 1115
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap char[] double[] char[] double[] int int int int
      StackMap stack:
            iload 8 /* slot */
            iconst_1
            iadd
            iload 5 /* mask */
            iand
            istore 8 /* slot */
        15: .line 1114
      StackMap locals:
      StackMap stack:
            aload 3 /* keys */
            iload 8 /* slot */
            caload
            ifne 14
        16: .line 1117
            aload 3 /* keys */
            iload 8 /* slot */
            iload 6 /* existing */
            castore
        17: .line 1118
            aload 4 /* values */
            iload 8 /* slot */
            aload 2 /* fromValues */
            iload 7 /* from */
            daload
            dastore
        end local 8 // int slot
        end local 6 // char existing
        18: .line 1111
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap char[] double[] char[] double[] int top int
      StackMap stack:
            iinc 7 /* from */ -1
            iload 7 /* from */
            ifge 10
        19: .line 1121
            return
        end local 7 // int from
        end local 5 // int mask
        end local 4 // double[] values
        end local 3 // char[] keys
        end local 2 // double[] fromValues
        end local 1 // char[] fromKeys
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   20     0        this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   20     1    fromKeys  [C
            0   20     2  fromValues  [D
            4   20     3        keys  [C
            5   20     4      values  [D
            6   20     5        mask  I
           11   18     6    existing  C
            7   20     7        from  I
           13   18     8        slot  I
    MethodParameters:
            Name  Flags
      fromKeys    
      fromValues  

  protected void allocateBuffers(int);
    descriptor: (I)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=9, locals=6, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // int arraySize
         0: .line 1128
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 1
            iload 1 /* arraySize */
            invokestatic java.lang.Integer.bitCount:(I)I
            iconst_1
            if_icmpeq 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 1131
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.orderMixer:Lcom/carrotsearch/hppc/HashOrderMixingStrategy;
            iload 1 /* arraySize */
            invokeinterface com.carrotsearch.hppc.HashOrderMixingStrategy.newKeyMixer:(I)I
            istore 2 /* newKeyMixer */
        start local 2 // int newKeyMixer
         2: .line 1134
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 3 /* prevKeys */
        start local 3 // char[] prevKeys
         3: .line 1135
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            astore 4 /* prevValues */
        start local 4 // double[] prevValues
         4: .line 1137
            iconst_1
            istore 5 /* emptyElementSlot */
        start local 5 // int emptyElementSlot
         5: .line 1138
            aload 0 /* this */
            iload 1 /* arraySize */
            iload 5 /* emptyElementSlot */
            iadd
            newarray 5
            putfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
         6: .line 1139
            aload 0 /* this */
            iload 1 /* arraySize */
            iload 5 /* emptyElementSlot */
            iadd
            newarray 7
            putfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
        end local 5 // int emptyElementSlot
         7: .line 1140
            goto 17
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap int int char[] double[]
      StackMap stack: java.lang.OutOfMemoryError
         8: astore 5 /* e */
        start local 5 // java.lang.OutOfMemoryError e
         9: .line 1141
            aload 0 /* this */
            aload 3 /* prevKeys */
            putfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
        10: .line 1142
            aload 0 /* this */
            aload 4 /* prevValues */
            putfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
        11: .line 1143
            new com.carrotsearch.hppc.BufferAllocationException
            dup
        12: .line 1144
            ldc "Not enough memory to allocate buffers for rehashing: %,d -> %,d"
        13: .line 1145
            aload 5 /* e */
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
        14: .line 1146
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_1
        15: .line 1147
            iload 1 /* arraySize */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
        16: .line 1143
            aastore
            invokespecial com.carrotsearch.hppc.BufferAllocationException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;[Ljava/lang/Object;)V
            athrow
        end local 5 // java.lang.OutOfMemoryError e
        17: .line 1150
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* arraySize */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.loadFactor:D
            invokestatic com.carrotsearch.hppc.HashContainers.expandAtCount:(ID)I
            putfield com.carrotsearch.hppc.CharDoubleHashMap.resizeAt:I
        18: .line 1151
            aload 0 /* this */
            iload 2 /* newKeyMixer */
            putfield com.carrotsearch.hppc.CharDoubleHashMap.keyMixer:I
        19: .line 1152
            aload 0 /* this */
            iload 1 /* arraySize */
            iconst_1
            isub
            putfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
        20: .line 1153
            return
        end local 4 // double[] prevValues
        end local 3 // char[] prevKeys
        end local 2 // int newKeyMixer
        end local 1 // int arraySize
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   21     0              this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   21     1         arraySize  I
            2   21     2       newKeyMixer  I
            3   21     3          prevKeys  [C
            4   21     4        prevValues  [D
            5    7     5  emptyElementSlot  I
            9   17     5                 e  Ljava/lang/OutOfMemoryError;
      Exception table:
        from    to  target  type
           4     7       8  Class java.lang.OutOfMemoryError
    MethodParameters:
           Name  Flags
      arraySize  

  protected void allocateThenInsertThenRehash(int, char, double);
    descriptor: (ICD)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=7, args_size=4
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // int slot
        start local 2 // char pendingKey
        start local 3 // double pendingValue
         0: .line 1165
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 4
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.resizeAt:I
            if_icmpne 3
         1: .line 1166
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            iload 1 /* slot */
            caload
            ifne 3
         2: .line 1167
            iload 2 /* pendingKey */
            ifne 4
      StackMap locals:
      StackMap stack:
         3: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         4: .line 1170
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 5 /* prevKeys */
        start local 5 // char[] prevKeys
         5: .line 1171
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            astore 6 /* prevValues */
        start local 6 // double[] prevValues
         6: .line 1172
            aload 0 /* this */
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            iconst_1
            iadd
            aload 0 /* this */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.size:()I
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.loadFactor:D
            invokestatic com.carrotsearch.hppc.HashContainers.nextBufferSize:(IID)I
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.allocateBuffers:(I)V
         7: .line 1173
            getstatic com.carrotsearch.hppc.CharDoubleHashMap.$assertionsDisabled:Z
            ifne 8
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            arraylength
            aload 5 /* prevKeys */
            arraylength
            if_icmpgt 8
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         8: .line 1177
      StackMap locals: char[] double[]
      StackMap stack:
            aload 5 /* prevKeys */
            iload 1 /* slot */
            iload 2 /* pendingKey */
            castore
         9: .line 1178
            aload 6 /* prevValues */
            iload 1 /* slot */
            dload 3 /* pendingValue */
            dastore
        10: .line 1181
            aload 0 /* this */
            aload 5 /* prevKeys */
            aload 6 /* prevValues */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.rehash:([C[D)V
        11: .line 1182
            return
        end local 6 // double[] prevValues
        end local 5 // char[] prevKeys
        end local 3 // double pendingValue
        end local 2 // char pendingKey
        end local 1 // int slot
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   12     0          this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   12     1          slot  I
            0   12     2    pendingKey  C
            0   12     3  pendingValue  D
            5   12     5      prevKeys  [C
            6   12     6    prevValues  [D
    MethodParameters:
              Name  Flags
      slot          
      pendingKey    
      pendingValue  

  protected void shiftConflictingKeys(int);
    descriptor: (I)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=10, args_size=2
        start local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
        start local 1 // int gapSlot
         0: .line 1189
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.keys:[C
            astore 2 /* keys */
        start local 2 // char[] keys
         1: .line 1190
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.values:[D
            astore 3 /* values */
        start local 3 // double[] values
         2: .line 1191
            aload 0 /* this */
            getfield com.carrotsearch.hppc.CharDoubleHashMap.mask:I
            istore 4 /* mask */
        start local 4 // int mask
         3: .line 1194
            iconst_0
            istore 5 /* distance */
        start local 5 // int distance
         4: .line 1196
      StackMap locals: com.carrotsearch.hppc.CharDoubleHashMap int char[] double[] int int
      StackMap stack:
            iload 1 /* gapSlot */
            iinc 5 /* distance */ 1
            iload 5 /* distance */
            iadd
            iload 4 /* mask */
            iand
            istore 6 /* slot */
        start local 6 // int slot
         5: .line 1197
            aload 2 /* keys */
            iload 6 /* slot */
            caload
            istore 7 /* existing */
        start local 7 // char existing
         6: .line 1198
            iload 7 /* existing */
            ifne 8
         7: .line 1199
            goto 16
         8: .line 1202
      StackMap locals: int int
      StackMap stack:
            aload 0 /* this */
            iload 7 /* existing */
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.hashKey:(C)I
            istore 8 /* idealSlot */
        start local 8 // int idealSlot
         9: .line 1203
            iload 6 /* slot */
            iload 8 /* idealSlot */
            isub
            iload 4 /* mask */
            iand
            istore 9 /* shift */
        start local 9 // int shift
        10: .line 1204
            iload 9 /* shift */
            iload 5 /* distance */
            if_icmplt 4
        11: .line 1209
            aload 2 /* keys */
            iload 1 /* gapSlot */
            iload 7 /* existing */
            castore
        12: .line 1210
            aload 3 /* values */
            iload 1 /* gapSlot */
            aload 3 /* values */
            iload 6 /* slot */
            daload
            dastore
        13: .line 1211
            iload 6 /* slot */
            istore 1 /* gapSlot */
        14: .line 1212
            iconst_0
            istore 5 /* distance */
        end local 9 // int shift
        end local 8 // int idealSlot
        end local 7 // char existing
        end local 6 // int slot
        15: .line 1195
            goto 4
        16: .line 1217
      StackMap locals:
      StackMap stack:
            aload 2 /* keys */
            iload 1 /* gapSlot */
            iconst_0
            castore
        17: .line 1218
            aload 3 /* values */
            iload 1 /* gapSlot */
            dconst_0
            dastore
        18: .line 1219
            aload 0 /* this */
            dup
            getfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
            iconst_1
            isub
            putfield com.carrotsearch.hppc.CharDoubleHashMap.assigned:I
        19: .line 1220
            return
        end local 5 // int distance
        end local 4 // int mask
        end local 3 // double[] values
        end local 2 // char[] keys
        end local 1 // int gapSlot
        end local 0 // com.carrotsearch.hppc.CharDoubleHashMap this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   20     0       this  Lcom/carrotsearch/hppc/CharDoubleHashMap;
            0   20     1    gapSlot  I
            1   20     2       keys  [C
            2   20     3     values  [D
            3   20     4       mask  I
            4   20     5   distance  I
            5   15     6       slot  I
            6   15     7   existing  C
            9   15     8  idealSlot  I
           10   15     9      shift  I
    MethodParameters:
         Name  Flags
      gapSlot  

  public com.carrotsearch.hppc.CharCollection keys();
    descriptor: ()Lcom/carrotsearch/hppc/CharCollection;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.keys:()Lcom/carrotsearch/hppc/CharDoubleHashMap$KeysContainer;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public com.carrotsearch.hppc.DoubleContainer values();
    descriptor: ()Lcom/carrotsearch/hppc/DoubleContainer;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.values:()Lcom/carrotsearch/hppc/DoubleCollection;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public java.lang.Object clone();
    descriptor: ()Ljava/lang/Object;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual com.carrotsearch.hppc.CharDoubleHashMap.clone:()Lcom/carrotsearch/hppc/CharDoubleHashMap;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.lang.CloneNotSupportedException
}
SourceFile: "CharDoubleHashMap.java"
NestMembers:
  com.carrotsearch.hppc.CharDoubleHashMap$EntryIterator  com.carrotsearch.hppc.CharDoubleHashMap$KeysContainer  com.carrotsearch.hppc.CharDoubleHashMap$KeysContainer$1  com.carrotsearch.hppc.CharDoubleHashMap$KeysContainer$2  com.carrotsearch.hppc.CharDoubleHashMap$KeysIterator  com.carrotsearch.hppc.CharDoubleHashMap$ValuesContainer  com.carrotsearch.hppc.CharDoubleHashMap$ValuesContainer$1  com.carrotsearch.hppc.CharDoubleHashMap$ValuesContainer$2  com.carrotsearch.hppc.CharDoubleHashMap$ValuesIterator
InnerClasses:
  private final EntryIterator = com.carrotsearch.hppc.CharDoubleHashMap$EntryIterator of com.carrotsearch.hppc.CharDoubleHashMap
  public final KeysContainer = com.carrotsearch.hppc.CharDoubleHashMap$KeysContainer of com.carrotsearch.hppc.CharDoubleHashMap
  private final KeysIterator = com.carrotsearch.hppc.CharDoubleHashMap$KeysIterator of com.carrotsearch.hppc.CharDoubleHashMap
  private final ValuesContainer = com.carrotsearch.hppc.CharDoubleHashMap$ValuesContainer of com.carrotsearch.hppc.CharDoubleHashMap
  private final ValuesIterator = com.carrotsearch.hppc.CharDoubleHashMap$ValuesIterator of com.carrotsearch.hppc.CharDoubleHashMap