public class java.util.PriorityQueue<E> extends java.util.AbstractQueue<E> implements java.io.Serializable
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: java.util.PriorityQueue
  super_class: java.util.AbstractQueue
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: -7720805057305804111

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

  transient java.lang.Object[] queue;
    descriptor: [Ljava/lang/Object;
    flags: (0x0080) ACC_TRANSIENT

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

  private final java.util.Comparator<? super E> comparator;
    descriptor: Ljava/util/Comparator;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Comparator<-TE;>;

  transient int modCount;
    descriptor: I
    flags: (0x0080) ACC_TRANSIENT

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

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // java.util.PriorityQueue this
         0: .line 123
            aload 0 /* this */
            bipush 11
            aconst_null
            invokespecial java.util.PriorityQueue.<init>:(ILjava/util/Comparator;)V
         1: .line 124
            return
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljava/util/PriorityQueue<TE;>;

  public void <init>(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // int initialCapacity
         0: .line 136
            aload 0 /* this */
            iload 1 /* initialCapacity */
            aconst_null
            invokespecial java.util.PriorityQueue.<init>:(ILjava/util/Comparator;)V
         1: .line 137
            return
        end local 1 // int initialCapacity
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    2     0             this  Ljava/util/PriorityQueue<TE;>;
            0    2     1  initialCapacity  I
    MethodParameters:
                 Name  Flags
      initialCapacity  

  public void <init>(java.util.Comparator<? super E>);
    descriptor: (Ljava/util/Comparator;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.util.Comparator comparator
         0: .line 149
            aload 0 /* this */
            bipush 11
            aload 1 /* comparator */
            invokespecial java.util.PriorityQueue.<init>:(ILjava/util/Comparator;)V
         1: .line 150
            return
        end local 1 // java.util.Comparator comparator
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Ljava/util/PriorityQueue<TE;>;
            0    2     1  comparator  Ljava/util/Comparator<-TE;>;
    Signature: (Ljava/util/Comparator<-TE;>;)V
    MethodParameters:
            Name  Flags
      comparator  

  public void <init>(int, java.util.Comparator<? super E>);
    descriptor: (ILjava/util/Comparator;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // java.util.PriorityQueue this
        start local 1 // int initialCapacity
        start local 2 // java.util.Comparator comparator
         0: .line 163
            aload 0 /* this */
            invokespecial java.util.AbstractQueue.<init>:()V
         1: .line 103
            aload 0 /* this */
            iconst_0
            putfield java.util.PriorityQueue.size:I
         2: .line 115
            aload 0 /* this */
            iconst_0
            putfield java.util.PriorityQueue.modCount:I
         3: .line 167
            iload 1 /* initialCapacity */
            iconst_1
            if_icmpge 5
         4: .line 168
            new java.lang.IllegalArgumentException
            dup
            invokespecial java.lang.IllegalArgumentException.<init>:()V
            athrow
         5: .line 169
      StackMap locals: java.util.PriorityQueue int java.util.Comparator
      StackMap stack:
            aload 0 /* this */
            iload 1 /* initialCapacity */
            anewarray java.lang.Object
            putfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
         6: .line 170
            aload 0 /* this */
            aload 2 /* comparator */
            putfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
         7: .line 171
            return
        end local 2 // java.util.Comparator comparator
        end local 1 // int initialCapacity
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    8     0             this  Ljava/util/PriorityQueue<TE;>;
            0    8     1  initialCapacity  I
            0    8     2       comparator  Ljava/util/Comparator<-TE;>;
    Signature: (ILjava/util/Comparator<-TE;>;)V
    MethodParameters:
                 Name  Flags
      initialCapacity  
      comparator       

  public void <init>(java.util.Collection<? extends E>);
    descriptor: (Ljava/util/Collection;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.util.Collection c
         0: .line 190
            aload 0 /* this */
            invokespecial java.util.AbstractQueue.<init>:()V
         1: .line 103
            aload 0 /* this */
            iconst_0
            putfield java.util.PriorityQueue.size:I
         2: .line 115
            aload 0 /* this */
            iconst_0
            putfield java.util.PriorityQueue.modCount:I
         3: .line 191
            aload 1 /* c */
            instanceof java.util.SortedSet
            ifeq 8
         4: .line 192
            aload 1 /* c */
            checkcast java.util.SortedSet
            astore 2 /* ss */
        start local 2 // java.util.SortedSet ss
         5: .line 193
            aload 0 /* this */
            aload 2 /* ss */
            invokeinterface java.util.SortedSet.comparator:()Ljava/util/Comparator;
            putfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
         6: .line 194
            aload 0 /* this */
            aload 2 /* ss */
            invokevirtual java.util.PriorityQueue.initElementsFromCollection:(Ljava/util/Collection;)V
        end local 2 // java.util.SortedSet ss
         7: .line 195
            goto 15
         8: .line 196
      StackMap locals: java.util.PriorityQueue java.util.Collection
      StackMap stack:
            aload 1 /* c */
            instanceof java.util.PriorityQueue
            ifeq 13
         9: .line 197
            aload 1 /* c */
            checkcast java.util.PriorityQueue
            astore 2 /* pq */
        start local 2 // java.util.PriorityQueue pq
        10: .line 198
            aload 0 /* this */
            aload 2 /* pq */
            invokevirtual java.util.PriorityQueue.comparator:()Ljava/util/Comparator;
            putfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
        11: .line 199
            aload 0 /* this */
            aload 2 /* pq */
            invokevirtual java.util.PriorityQueue.initFromPriorityQueue:(Ljava/util/PriorityQueue;)V
        end local 2 // java.util.PriorityQueue pq
        12: .line 200
            goto 15
        13: .line 202
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
        14: .line 203
            aload 0 /* this */
            aload 1 /* c */
            invokevirtual java.util.PriorityQueue.initFromCollection:(Ljava/util/Collection;)V
        15: .line 205
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.util.Collection c
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   16     0  this  Ljava/util/PriorityQueue<TE;>;
            0   16     1     c  Ljava/util/Collection<+TE;>;
            5    7     2    ss  Ljava/util/SortedSet<+TE;>;
           10   12     2    pq  Ljava/util/PriorityQueue<+TE;>;
    Signature: (Ljava/util/Collection<+TE;>;)V
    MethodParameters:
      Name  Flags
      c     

  public void <init>(java.util.PriorityQueue<? extends E>);
    descriptor: (Ljava/util/PriorityQueue;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.util.PriorityQueue c
         0: .line 222
            aload 0 /* this */
            invokespecial java.util.AbstractQueue.<init>:()V
         1: .line 103
            aload 0 /* this */
            iconst_0
            putfield java.util.PriorityQueue.size:I
         2: .line 115
            aload 0 /* this */
            iconst_0
            putfield java.util.PriorityQueue.modCount:I
         3: .line 223
            aload 0 /* this */
            aload 1 /* c */
            invokevirtual java.util.PriorityQueue.comparator:()Ljava/util/Comparator;
            putfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
         4: .line 224
            aload 0 /* this */
            aload 1 /* c */
            invokevirtual java.util.PriorityQueue.initFromPriorityQueue:(Ljava/util/PriorityQueue;)V
         5: .line 225
            return
        end local 1 // java.util.PriorityQueue c
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Ljava/util/PriorityQueue<TE;>;
            0    6     1     c  Ljava/util/PriorityQueue<+TE;>;
    Signature: (Ljava/util/PriorityQueue<+TE;>;)V
    MethodParameters:
      Name  Flags
      c     

  public void <init>(java.util.SortedSet<? extends E>);
    descriptor: (Ljava/util/SortedSet;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.util.SortedSet c
         0: .line 241
            aload 0 /* this */
            invokespecial java.util.AbstractQueue.<init>:()V
         1: .line 103
            aload 0 /* this */
            iconst_0
            putfield java.util.PriorityQueue.size:I
         2: .line 115
            aload 0 /* this */
            iconst_0
            putfield java.util.PriorityQueue.modCount:I
         3: .line 242
            aload 0 /* this */
            aload 1 /* c */
            invokeinterface java.util.SortedSet.comparator:()Ljava/util/Comparator;
            putfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
         4: .line 243
            aload 0 /* this */
            aload 1 /* c */
            invokevirtual java.util.PriorityQueue.initElementsFromCollection:(Ljava/util/Collection;)V
         5: .line 244
            return
        end local 1 // java.util.SortedSet c
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Ljava/util/PriorityQueue<TE;>;
            0    6     1     c  Ljava/util/SortedSet<+TE;>;
    Signature: (Ljava/util/SortedSet<+TE;>;)V
    MethodParameters:
      Name  Flags
      c     

  private void initFromPriorityQueue(java.util.PriorityQueue<? extends E>);
    descriptor: (Ljava/util/PriorityQueue;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.util.PriorityQueue c
         0: .line 247
            aload 1 /* c */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            ldc Ljava/util/PriorityQueue;
            if_acmpne 4
         1: .line 248
            aload 0 /* this */
            aload 1 /* c */
            invokevirtual java.util.PriorityQueue.toArray:()[Ljava/lang/Object;
            putfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
         2: .line 249
            aload 0 /* this */
            aload 1 /* c */
            invokevirtual java.util.PriorityQueue.size:()I
            putfield java.util.PriorityQueue.size:I
         3: .line 250
            goto 5
         4: .line 251
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* c */
            invokevirtual java.util.PriorityQueue.initFromCollection:(Ljava/util/Collection;)V
         5: .line 253
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.util.PriorityQueue c
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Ljava/util/PriorityQueue<TE;>;
            0    6     1     c  Ljava/util/PriorityQueue<+TE;>;
    Signature: (Ljava/util/PriorityQueue<+TE;>;)V
    MethodParameters:
      Name  Flags
      c     

  private void initElementsFromCollection(java.util.Collection<? extends E>);
    descriptor: (Ljava/util/Collection;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.util.Collection c
         0: .line 256
            aload 1 /* c */
            invokeinterface java.util.Collection.toArray:()[Ljava/lang/Object;
            astore 2 /* a */
        start local 2 // java.lang.Object[] a
         1: .line 257
            aload 1 /* c */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            ldc Ljava/util/ArrayList;
            if_acmpeq 3
         2: .line 258
            aload 2 /* a */
            aload 2 /* a */
            arraylength
            ldc [Ljava/lang/Object;
            invokestatic java.util.Arrays.copyOf:([Ljava/lang/Object;ILjava/lang/Class;)[Ljava/lang/Object;
            astore 2 /* a */
         3: .line 259
      StackMap locals: java.lang.Object[]
      StackMap stack:
            aload 2 /* a */
            arraylength
            istore 3 /* len */
        start local 3 // int len
         4: .line 260
            iload 3 /* len */
            iconst_1
            if_icmpeq 5
            aload 0 /* this */
            getfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
            ifnull 11
         5: .line 261
      StackMap locals: int
      StackMap stack:
            iconst_0
            istore 4 /* i */
        start local 4 // int i
         6: goto 10
         7: .line 262
      StackMap locals: int
      StackMap stack:
            aload 2 /* a */
            iload 4 /* i */
            aaload
            ifnonnull 9
         8: .line 263
            new java.lang.NullPointerException
            dup
            invokespecial java.lang.NullPointerException.<init>:()V
            athrow
         9: .line 261
      StackMap locals:
      StackMap stack:
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
        10: iload 4 /* i */
            iload 3 /* len */
            if_icmplt 7
        end local 4 // int i
        11: .line 264
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* a */
            putfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
        12: .line 265
            aload 0 /* this */
            aload 2 /* a */
            arraylength
            putfield java.util.PriorityQueue.size:I
        13: .line 266
            return
        end local 3 // int len
        end local 2 // java.lang.Object[] a
        end local 1 // java.util.Collection c
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   14     0  this  Ljava/util/PriorityQueue<TE;>;
            0   14     1     c  Ljava/util/Collection<+TE;>;
            1   14     2     a  [Ljava/lang/Object;
            4   14     3   len  I
            6   11     4     i  I
    Signature: (Ljava/util/Collection<+TE;>;)V
    MethodParameters:
      Name  Flags
      c     

  private void initFromCollection(java.util.Collection<? extends E>);
    descriptor: (Ljava/util/Collection;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.util.Collection c
         0: .line 274
            aload 0 /* this */
            aload 1 /* c */
            invokevirtual java.util.PriorityQueue.initElementsFromCollection:(Ljava/util/Collection;)V
         1: .line 275
            aload 0 /* this */
            invokevirtual java.util.PriorityQueue.heapify:()V
         2: .line 276
            return
        end local 1 // java.util.Collection c
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljava/util/PriorityQueue<TE;>;
            0    3     1     c  Ljava/util/Collection<+TE;>;
    Signature: (Ljava/util/Collection<+TE;>;)V
    MethodParameters:
      Name  Flags
      c     

  private void grow(int);
    descriptor: (I)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // int minCapacity
         0: .line 292
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            arraylength
            istore 2 /* oldCapacity */
        start local 2 // int oldCapacity
         1: .line 294
            iload 2 /* oldCapacity */
            iload 2 /* oldCapacity */
            bipush 64
            if_icmpge 3
         2: .line 295
            iload 2 /* oldCapacity */
            iconst_2
            iadd
            goto 4
         3: .line 296
      StackMap locals: java.util.PriorityQueue int int
      StackMap stack: int
            iload 2 /* oldCapacity */
            iconst_1
            ishr
         4: .line 294
      StackMap locals: java.util.PriorityQueue int int
      StackMap stack: int int
            iadd
            istore 3 /* newCapacity */
        start local 3 // int newCapacity
         5: .line 298
            iload 3 /* newCapacity */
            ldc 2147483639
            isub
            ifle 7
         6: .line 299
            iload 1 /* minCapacity */
            invokestatic java.util.PriorityQueue.hugeCapacity:(I)I
            istore 3 /* newCapacity */
         7: .line 300
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 3 /* newCapacity */
            invokestatic java.util.Arrays.copyOf:([Ljava/lang/Object;I)[Ljava/lang/Object;
            putfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
         8: .line 301
            return
        end local 3 // int newCapacity
        end local 2 // int oldCapacity
        end local 1 // int minCapacity
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    9     0         this  Ljava/util/PriorityQueue<TE;>;
            0    9     1  minCapacity  I
            1    9     2  oldCapacity  I
            5    9     3  newCapacity  I
    MethodParameters:
             Name  Flags
      minCapacity  

  private static int hugeCapacity(int);
    descriptor: (I)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // int minCapacity
         0: .line 304
            iload 0 /* minCapacity */
            ifge 2
         1: .line 305
            new java.lang.OutOfMemoryError
            dup
            invokespecial java.lang.OutOfMemoryError.<init>:()V
            athrow
         2: .line 306
      StackMap locals:
      StackMap stack:
            iload 0 /* minCapacity */
            ldc 2147483639
            if_icmple 4
         3: .line 307
            ldc 2147483647
            goto 5
         4: .line 308
      StackMap locals:
      StackMap stack:
            ldc 2147483639
         5: .line 306
      StackMap locals:
      StackMap stack: int
            ireturn
        end local 0 // int minCapacity
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    6     0  minCapacity  I
    MethodParameters:
             Name  Flags
      minCapacity  

  public boolean add();
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.lang.Object e
         0: .line 321
            aload 0 /* this */
            aload 1 /* e */
            invokevirtual java.util.PriorityQueue.offer:(Ljava/lang/Object;)Z
            ireturn
        end local 1 // java.lang.Object e
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/util/PriorityQueue<TE;>;
            0    1     1     e  TE;
    Signature: (TE;)Z
    MethodParameters:
      Name  Flags
      e     

  public boolean offer();
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.lang.Object e
         0: .line 334
            aload 1 /* e */
            ifnonnull 2
         1: .line 335
            new java.lang.NullPointerException
            dup
            invokespecial java.lang.NullPointerException.<init>:()V
            athrow
         2: .line 336
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield java.util.PriorityQueue.modCount:I
            iconst_1
            iadd
            putfield java.util.PriorityQueue.modCount:I
         3: .line 337
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            istore 2 /* i */
        start local 2 // int i
         4: .line 338
            iload 2 /* i */
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            arraylength
            if_icmplt 6
         5: .line 339
            aload 0 /* this */
            iload 2 /* i */
            iconst_1
            iadd
            invokevirtual java.util.PriorityQueue.grow:(I)V
         6: .line 340
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            iload 2 /* i */
            iconst_1
            iadd
            putfield java.util.PriorityQueue.size:I
         7: .line 341
            iload 2 /* i */
            ifne 9
         8: .line 342
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iconst_0
            aload 1 /* e */
            aastore
            goto 10
         9: .line 344
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 2 /* i */
            aload 1 /* e */
            invokevirtual java.util.PriorityQueue.siftUp:(ILjava/lang/Object;)V
        10: .line 345
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 2 // int i
        end local 1 // java.lang.Object e
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Ljava/util/PriorityQueue<TE;>;
            0   11     1     e  TE;
            4   11     2     i  I
    Signature: (TE;)Z
    MethodParameters:
      Name  Flags
      e     

  public E peek();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.util.PriorityQueue this
         0: .line 350
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            ifne 1
            aconst_null
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iconst_0
            aaload
      StackMap locals:
      StackMap stack: java.lang.Object
         2: areturn
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljava/util/PriorityQueue<TE;>;
    Signature: ()TE;

  private int indexOf(java.lang.Object);
    descriptor: (Ljava/lang/Object;)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.lang.Object o
         0: .line 354
            aload 1 /* o */
            ifnull 7
         1: .line 355
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         2: goto 6
         3: .line 356
      StackMap locals: int
      StackMap stack:
            aload 1 /* o */
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 2 /* i */
            aaload
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 5
         4: .line 357
            iload 2 /* i */
            ireturn
         5: .line 355
      StackMap locals:
      StackMap stack:
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         6: iload 2 /* i */
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            if_icmplt 3
        end local 2 // int i
         7: .line 359
      StackMap locals:
      StackMap stack:
            iconst_m1
            ireturn
        end local 1 // java.lang.Object o
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Ljava/util/PriorityQueue<TE;>;
            0    8     1     o  Ljava/lang/Object;
            2    7     2     i  I
    MethodParameters:
      Name  Flags
      o     

  public boolean remove(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.lang.Object o
         0: .line 374
            aload 0 /* this */
            aload 1 /* o */
            invokevirtual java.util.PriorityQueue.indexOf:(Ljava/lang/Object;)I
            istore 2 /* i */
        start local 2 // int i
         1: .line 375
            iload 2 /* i */
            iconst_m1
            if_icmpne 3
         2: .line 376
            iconst_0
            ireturn
         3: .line 378
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            iload 2 /* i */
            invokevirtual java.util.PriorityQueue.removeAt:(I)Ljava/lang/Object;
            pop
         4: .line 379
            iconst_1
            ireturn
        end local 2 // int i
        end local 1 // java.lang.Object o
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Ljava/util/PriorityQueue<TE;>;
            0    5     1     o  Ljava/lang/Object;
            1    5     2     i  I
    MethodParameters:
      Name  Flags
      o     

  boolean removeEq(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.lang.Object o
         0: .line 391
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         1: goto 6
         2: .line 392
      StackMap locals: int
      StackMap stack:
            aload 1 /* o */
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 2 /* i */
            aaload
            if_acmpne 5
         3: .line 393
            aload 0 /* this */
            iload 2 /* i */
            invokevirtual java.util.PriorityQueue.removeAt:(I)Ljava/lang/Object;
            pop
         4: .line 394
            iconst_1
            ireturn
         5: .line 391
      StackMap locals:
      StackMap stack:
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         6: iload 2 /* i */
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            if_icmplt 2
        end local 2 // int i
         7: .line 397
            iconst_0
            ireturn
        end local 1 // java.lang.Object o
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Ljava/util/PriorityQueue<TE;>;
            0    8     1     o  Ljava/lang/Object;
            1    7     2     i  I
    MethodParameters:
      Name  Flags
      o     

  public boolean contains(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.lang.Object o
         0: .line 409
            aload 0 /* this */
            aload 1 /* o */
            invokevirtual java.util.PriorityQueue.indexOf:(Ljava/lang/Object;)I
            iconst_m1
            if_icmpeq 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 1 // java.lang.Object o
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljava/util/PriorityQueue<TE;>;
            0    2     1     o  Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      o     

  public java.lang.Object[] toArray();
    descriptor: ()[Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.util.PriorityQueue this
         0: .line 426
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            invokestatic java.util.Arrays.copyOf:([Ljava/lang/Object;I)[Ljava/lang/Object;
            areturn
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/util/PriorityQueue<TE;>;

  public <T> T[] toArray();
    descriptor: ([Ljava/lang/Object;)[Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.lang.Object[] a
         0: .line 467
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            istore 2 /* size */
        start local 2 // int size
         1: .line 468
            aload 1 /* a */
            arraylength
            iload 2 /* size */
            if_icmpge 3
         2: .line 470
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 2 /* size */
            aload 1 /* a */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokestatic java.util.Arrays.copyOf:([Ljava/lang/Object;ILjava/lang/Class;)[Ljava/lang/Object;
            areturn
         3: .line 471
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iconst_0
            aload 1 /* a */
            iconst_0
            iload 2 /* size */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         4: .line 472
            aload 1 /* a */
            arraylength
            iload 2 /* size */
            if_icmple 6
         5: .line 473
            aload 1 /* a */
            iload 2 /* size */
            aconst_null
            aastore
         6: .line 474
      StackMap locals:
      StackMap stack:
            aload 1 /* a */
            areturn
        end local 2 // int size
        end local 1 // java.lang.Object[] a
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Ljava/util/PriorityQueue<TE;>;
            0    7     1     a  [Ljava/lang/Object;
            1    7     2  size  I
    Signature: <T:Ljava/lang/Object;>([TT;)[TT;
    MethodParameters:
      Name  Flags
      a     

  public java.util.Iterator<E> iterator();
    descriptor: ()Ljava/util/Iterator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // java.util.PriorityQueue this
         0: .line 484
            new java.util.PriorityQueue$Itr
            dup
            aload 0 /* this */
            invokespecial java.util.PriorityQueue$Itr.<init>:(Ljava/util/PriorityQueue;)V
            areturn
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/util/PriorityQueue<TE;>;
    Signature: ()Ljava/util/Iterator<TE;>;

  public int size();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.util.PriorityQueue this
         0: .line 571
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            ireturn
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/util/PriorityQueue<TE;>;

  public void clear();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // java.util.PriorityQueue this
         0: .line 579
            aload 0 /* this */
            dup
            getfield java.util.PriorityQueue.modCount:I
            iconst_1
            iadd
            putfield java.util.PriorityQueue.modCount:I
         1: .line 580
            iconst_0
            istore 1 /* i */
        start local 1 // int i
         2: goto 5
         3: .line 581
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* i */
            aconst_null
            aastore
         4: .line 580
            iinc 1 /* i */ 1
      StackMap locals:
      StackMap stack:
         5: iload 1 /* i */
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            if_icmplt 3
        end local 1 // int i
         6: .line 582
            aload 0 /* this */
            iconst_0
            putfield java.util.PriorityQueue.size:I
         7: .line 583
            return
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Ljava/util/PriorityQueue<TE;>;
            2    6     1     i  I

  public E poll();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // java.util.PriorityQueue this
         0: .line 587
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            ifne 2
         1: .line 588
            aconst_null
            areturn
         2: .line 589
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield java.util.PriorityQueue.size:I
            iconst_1
            isub
            dup_x1
            putfield java.util.PriorityQueue.size:I
            istore 1 /* s */
        start local 1 // int s
         3: .line 590
            aload 0 /* this */
            dup
            getfield java.util.PriorityQueue.modCount:I
            iconst_1
            iadd
            putfield java.util.PriorityQueue.modCount:I
         4: .line 591
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iconst_0
            aaload
            astore 2 /* result */
        start local 2 // java.lang.Object result
         5: .line 592
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* s */
            aaload
            astore 3 /* x */
        start local 3 // java.lang.Object x
         6: .line 593
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* s */
            aconst_null
            aastore
         7: .line 594
            iload 1 /* s */
            ifeq 9
         8: .line 595
            aload 0 /* this */
            iconst_0
            aload 3 /* x */
            invokevirtual java.util.PriorityQueue.siftDown:(ILjava/lang/Object;)V
         9: .line 596
      StackMap locals: int java.lang.Object java.lang.Object
      StackMap stack:
            aload 2 /* result */
            areturn
        end local 3 // java.lang.Object x
        end local 2 // java.lang.Object result
        end local 1 // int s
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   10     0    this  Ljava/util/PriorityQueue<TE;>;
            3   10     1       s  I
            5   10     2  result  TE;
            6   10     3       x  TE;
    Signature: ()TE;

  private E removeAt();
    descriptor: (I)Ljava/lang/Object;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // int i
         0: .line 614
            aload 0 /* this */
            dup
            getfield java.util.PriorityQueue.modCount:I
            iconst_1
            iadd
            putfield java.util.PriorityQueue.modCount:I
         1: .line 615
            aload 0 /* this */
            dup
            getfield java.util.PriorityQueue.size:I
            iconst_1
            isub
            dup_x1
            putfield java.util.PriorityQueue.size:I
            istore 2 /* s */
        start local 2 // int s
         2: .line 616
            iload 2 /* s */
            iload 1 /* i */
            if_icmpne 4
         3: .line 617
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* i */
            aconst_null
            aastore
            goto 11
         4: .line 619
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 2 /* s */
            aaload
            astore 3 /* moved */
        start local 3 // java.lang.Object moved
         5: .line 620
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 2 /* s */
            aconst_null
            aastore
         6: .line 621
            aload 0 /* this */
            iload 1 /* i */
            aload 3 /* moved */
            invokevirtual java.util.PriorityQueue.siftDown:(ILjava/lang/Object;)V
         7: .line 622
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* i */
            aaload
            aload 3 /* moved */
            if_acmpne 11
         8: .line 623
            aload 0 /* this */
            iload 1 /* i */
            aload 3 /* moved */
            invokevirtual java.util.PriorityQueue.siftUp:(ILjava/lang/Object;)V
         9: .line 624
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* i */
            aaload
            aload 3 /* moved */
            if_acmpeq 11
        10: .line 625
            aload 3 /* moved */
            areturn
        end local 3 // java.lang.Object moved
        11: .line 628
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // int s
        end local 1 // int i
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   12     0   this  Ljava/util/PriorityQueue<TE;>;
            0   12     1      i  I
            2   12     2      s  I
            5   11     3  moved  TE;
    Signature: (I)TE;
    MethodParameters:
      Name  Flags
      i     

  private void siftUp(int, );
    descriptor: (ILjava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // java.util.PriorityQueue this
        start local 1 // int k
        start local 2 // java.lang.Object x
         0: .line 644
            aload 0 /* this */
            getfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
            ifnull 2
         1: .line 645
            aload 0 /* this */
            iload 1 /* k */
            aload 2 /* x */
            invokevirtual java.util.PriorityQueue.siftUpUsingComparator:(ILjava/lang/Object;)V
            goto 3
         2: .line 647
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* k */
            aload 2 /* x */
            invokevirtual java.util.PriorityQueue.siftUpComparable:(ILjava/lang/Object;)V
         3: .line 648
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.Object x
        end local 1 // int k
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Ljava/util/PriorityQueue<TE;>;
            0    4     1     k  I
            0    4     2     x  TE;
    Signature: (ITE;)V
    MethodParameters:
      Name  Flags
      k     
      x     

  private void siftUpComparable(int, );
    descriptor: (ILjava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=6, args_size=3
        start local 0 // java.util.PriorityQueue this
        start local 1 // int k
        start local 2 // java.lang.Object x
         0: .line 652
            aload 2 /* x */
            checkcast java.lang.Comparable
            astore 3 /* key */
        start local 3 // java.lang.Comparable key
         1: .line 653
            goto 8
         2: .line 654
      StackMap locals: java.lang.Comparable
      StackMap stack:
            iload 1 /* k */
            iconst_1
            isub
            iconst_1
            iushr
            istore 4 /* parent */
        start local 4 // int parent
         3: .line 655
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 4 /* parent */
            aaload
            astore 5 /* e */
        start local 5 // java.lang.Object e
         4: .line 656
            aload 3 /* key */
            aload 5 /* e */
            invokeinterface java.lang.Comparable.compareTo:(Ljava/lang/Object;)I
            iflt 6
         5: .line 657
            goto 9
         6: .line 658
      StackMap locals: int java.lang.Object
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* k */
            aload 5 /* e */
            aastore
         7: .line 659
            iload 4 /* parent */
            istore 1 /* k */
        end local 5 // java.lang.Object e
        end local 4 // int parent
         8: .line 653
      StackMap locals:
      StackMap stack:
            iload 1 /* k */
            ifgt 2
         9: .line 661
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* k */
            aload 3 /* key */
            aastore
        10: .line 662
            return
        end local 3 // java.lang.Comparable key
        end local 2 // java.lang.Object x
        end local 1 // int k
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   11     0    this  Ljava/util/PriorityQueue<TE;>;
            0   11     1       k  I
            0   11     2       x  TE;
            1   11     3     key  Ljava/lang/Comparable<-TE;>;
            3    8     4  parent  I
            4    8     5       e  Ljava/lang/Object;
    Signature: (ITE;)V
    MethodParameters:
      Name  Flags
      k     
      x     

  private void siftUpUsingComparator(int, );
    descriptor: (ILjava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // java.util.PriorityQueue this
        start local 1 // int k
        start local 2 // java.lang.Object x
         0: .line 666
            goto 7
         1: .line 667
      StackMap locals:
      StackMap stack:
            iload 1 /* k */
            iconst_1
            isub
            iconst_1
            iushr
            istore 3 /* parent */
        start local 3 // int parent
         2: .line 668
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 3 /* parent */
            aaload
            astore 4 /* e */
        start local 4 // java.lang.Object e
         3: .line 669
            aload 0 /* this */
            getfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
            aload 2 /* x */
            aload 4 /* e */
            invokeinterface java.util.Comparator.compare:(Ljava/lang/Object;Ljava/lang/Object;)I
            iflt 5
         4: .line 670
            goto 8
         5: .line 671
      StackMap locals: int java.lang.Object
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* k */
            aload 4 /* e */
            aastore
         6: .line 672
            iload 3 /* parent */
            istore 1 /* k */
        end local 4 // java.lang.Object e
        end local 3 // int parent
         7: .line 666
      StackMap locals:
      StackMap stack:
            iload 1 /* k */
            ifgt 1
         8: .line 674
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* k */
            aload 2 /* x */
            aastore
         9: .line 675
            return
        end local 2 // java.lang.Object x
        end local 1 // int k
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   10     0    this  Ljava/util/PriorityQueue<TE;>;
            0   10     1       k  I
            0   10     2       x  TE;
            2    7     3  parent  I
            3    7     4       e  Ljava/lang/Object;
    Signature: (ITE;)V
    MethodParameters:
      Name  Flags
      k     
      x     

  private void siftDown(int, );
    descriptor: (ILjava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // java.util.PriorityQueue this
        start local 1 // int k
        start local 2 // java.lang.Object x
         0: .line 686
            aload 0 /* this */
            getfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
            ifnull 2
         1: .line 687
            aload 0 /* this */
            iload 1 /* k */
            aload 2 /* x */
            invokevirtual java.util.PriorityQueue.siftDownUsingComparator:(ILjava/lang/Object;)V
            goto 3
         2: .line 689
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* k */
            aload 2 /* x */
            invokevirtual java.util.PriorityQueue.siftDownComparable:(ILjava/lang/Object;)V
         3: .line 690
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.Object x
        end local 1 // int k
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Ljava/util/PriorityQueue<TE;>;
            0    4     1     k  I
            0    4     2     x  TE;
    Signature: (ITE;)V
    MethodParameters:
      Name  Flags
      k     
      x     

  private void siftDownComparable(int, );
    descriptor: (ILjava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=8, args_size=3
        start local 0 // java.util.PriorityQueue this
        start local 1 // int k
        start local 2 // java.lang.Object x
         0: .line 694
            aload 2 /* x */
            checkcast java.lang.Comparable
            astore 3 /* key */
        start local 3 // java.lang.Comparable key
         1: .line 695
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            iconst_1
            iushr
            istore 4 /* half */
        start local 4 // int half
         2: .line 696
            goto 13
         3: .line 697
      StackMap locals: java.lang.Comparable int
      StackMap stack:
            iload 1 /* k */
            iconst_1
            ishl
            iconst_1
            iadd
            istore 5 /* child */
        start local 5 // int child
         4: .line 698
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 5 /* child */
            aaload
            astore 6 /* c */
        start local 6 // java.lang.Object c
         5: .line 699
            iload 5 /* child */
            iconst_1
            iadd
            istore 7 /* right */
        start local 7 // int right
         6: .line 700
            iload 7 /* right */
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            if_icmpge 9
         7: .line 701
            aload 6 /* c */
            checkcast java.lang.Comparable
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 7 /* right */
            aaload
            invokeinterface java.lang.Comparable.compareTo:(Ljava/lang/Object;)I
            ifle 9
         8: .line 702
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 7 /* right */
            dup
            istore 5 /* child */
            aaload
            astore 6 /* c */
         9: .line 703
      StackMap locals: int java.lang.Object int
      StackMap stack:
            aload 3 /* key */
            aload 6 /* c */
            invokeinterface java.lang.Comparable.compareTo:(Ljava/lang/Object;)I
            ifgt 11
        10: .line 704
            goto 14
        11: .line 705
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* k */
            aload 6 /* c */
            aastore
        12: .line 706
            iload 5 /* child */
            istore 1 /* k */
        end local 7 // int right
        end local 6 // java.lang.Object c
        end local 5 // int child
        13: .line 696
      StackMap locals:
      StackMap stack:
            iload 1 /* k */
            iload 4 /* half */
            if_icmplt 3
        14: .line 708
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* k */
            aload 3 /* key */
            aastore
        15: .line 709
            return
        end local 4 // int half
        end local 3 // java.lang.Comparable key
        end local 2 // java.lang.Object x
        end local 1 // int k
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   16     0   this  Ljava/util/PriorityQueue<TE;>;
            0   16     1      k  I
            0   16     2      x  TE;
            1   16     3    key  Ljava/lang/Comparable<-TE;>;
            2   16     4   half  I
            4   13     5  child  I
            5   13     6      c  Ljava/lang/Object;
            6   13     7  right  I
    Signature: (ITE;)V
    MethodParameters:
      Name  Flags
      k     
      x     

  private void siftDownUsingComparator(int, );
    descriptor: (ILjava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=7, args_size=3
        start local 0 // java.util.PriorityQueue this
        start local 1 // int k
        start local 2 // java.lang.Object x
         0: .line 713
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            iconst_1
            iushr
            istore 3 /* half */
        start local 3 // int half
         1: .line 714
            goto 12
         2: .line 715
      StackMap locals: int
      StackMap stack:
            iload 1 /* k */
            iconst_1
            ishl
            iconst_1
            iadd
            istore 4 /* child */
        start local 4 // int child
         3: .line 716
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 4 /* child */
            aaload
            astore 5 /* c */
        start local 5 // java.lang.Object c
         4: .line 717
            iload 4 /* child */
            iconst_1
            iadd
            istore 6 /* right */
        start local 6 // int right
         5: .line 718
            iload 6 /* right */
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            if_icmpge 8
         6: .line 719
            aload 0 /* this */
            getfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
            aload 5 /* c */
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 6 /* right */
            aaload
            invokeinterface java.util.Comparator.compare:(Ljava/lang/Object;Ljava/lang/Object;)I
            ifle 8
         7: .line 720
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 6 /* right */
            dup
            istore 4 /* child */
            aaload
            astore 5 /* c */
         8: .line 721
      StackMap locals: int java.lang.Object int
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
            aload 2 /* x */
            aload 5 /* c */
            invokeinterface java.util.Comparator.compare:(Ljava/lang/Object;Ljava/lang/Object;)I
            ifgt 10
         9: .line 722
            goto 13
        10: .line 723
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* k */
            aload 5 /* c */
            aastore
        11: .line 724
            iload 4 /* child */
            istore 1 /* k */
        end local 6 // int right
        end local 5 // java.lang.Object c
        end local 4 // int child
        12: .line 714
      StackMap locals:
      StackMap stack:
            iload 1 /* k */
            iload 3 /* half */
            if_icmplt 2
        13: .line 726
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* k */
            aload 2 /* x */
            aastore
        14: .line 727
            return
        end local 3 // int half
        end local 2 // java.lang.Object x
        end local 1 // int k
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   15     0   this  Ljava/util/PriorityQueue<TE;>;
            0   15     1      k  I
            0   15     2      x  TE;
            1   15     3   half  I
            3   12     4  child  I
            4   12     5      c  Ljava/lang/Object;
            5   12     6  right  I
    Signature: (ITE;)V
    MethodParameters:
      Name  Flags
      k     
      x     

  private void heapify();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // java.util.PriorityQueue this
         0: .line 735
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            iconst_1
            iushr
            iconst_1
            isub
            istore 1 /* i */
        start local 1 // int i
         1: goto 4
         2: .line 736
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            iload 1 /* i */
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 1 /* i */
            aaload
            invokevirtual java.util.PriorityQueue.siftDown:(ILjava/lang/Object;)V
         3: .line 735
            iinc 1 /* i */ -1
      StackMap locals:
      StackMap stack:
         4: iload 1 /* i */
            ifge 2
        end local 1 // int i
         5: .line 737
            return
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Ljava/util/PriorityQueue<TE;>;
            1    5     1     i  I

  public java.util.Comparator<? super E> comparator();
    descriptor: ()Ljava/util/Comparator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.util.PriorityQueue this
         0: .line 749
            aload 0 /* this */
            getfield java.util.PriorityQueue.comparator:Ljava/util/Comparator;
            areturn
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/util/PriorityQueue<TE;>;
    Signature: ()Ljava/util/Comparator<-TE;>;

  private void writeObject(java.io.ObjectOutputStream);
    descriptor: (Ljava/io/ObjectOutputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.io.ObjectOutputStream s
         0: .line 763
            aload 1 /* s */
            invokevirtual java.io.ObjectOutputStream.defaultWriteObject:()V
         1: .line 766
            aload 1 /* s */
            iconst_2
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            iconst_1
            iadd
            invokestatic java.lang.Math.max:(II)I
            invokevirtual java.io.ObjectOutputStream.writeInt:(I)V
         2: .line 769
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         3: goto 6
         4: .line 770
      StackMap locals: int
      StackMap stack:
            aload 1 /* s */
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 2 /* i */
            aaload
            invokevirtual java.io.ObjectOutputStream.writeObject:(Ljava/lang/Object;)V
         5: .line 769
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         6: iload 2 /* i */
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            if_icmplt 4
        end local 2 // int i
         7: .line 771
            return
        end local 1 // java.io.ObjectOutputStream s
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Ljava/util/PriorityQueue<TE;>;
            0    8     1     s  Ljava/io/ObjectOutputStream;
            3    7     2     i  I
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      s     

  private void readObject(java.io.ObjectInputStream);
    descriptor: (Ljava/io/ObjectInputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // java.util.PriorityQueue this
        start local 1 // java.io.ObjectInputStream s
         0: .line 782
            aload 1 /* s */
            invokevirtual java.io.ObjectInputStream.defaultReadObject:()V
         1: .line 785
            aload 1 /* s */
            invokevirtual java.io.ObjectInputStream.readInt:()I
            pop
         2: .line 787
            invokestatic sun.misc.SharedSecrets.getJavaOISAccess:()Lsun/misc/JavaOISAccess;
            aload 1 /* s */
            ldc [Ljava/lang/Object;
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            invokeinterface sun.misc.JavaOISAccess.checkArray:(Ljava/io/ObjectInputStream;Ljava/lang/Class;I)V
         3: .line 788
            aload 0 /* this */
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            anewarray java.lang.Object
            putfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
         4: .line 791
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         5: goto 8
         6: .line 792
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield java.util.PriorityQueue.queue:[Ljava/lang/Object;
            iload 2 /* i */
            aload 1 /* s */
            invokevirtual java.io.ObjectInputStream.readObject:()Ljava/lang/Object;
            aastore
         7: .line 791
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         8: iload 2 /* i */
            aload 0 /* this */
            getfield java.util.PriorityQueue.size:I
            if_icmplt 6
        end local 2 // int i
         9: .line 796
            aload 0 /* this */
            invokevirtual java.util.PriorityQueue.heapify:()V
        10: .line 797
            return
        end local 1 // java.io.ObjectInputStream s
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Ljava/util/PriorityQueue<TE;>;
            0   11     1     s  Ljava/io/ObjectInputStream;
            5    9     2     i  I
    Exceptions:
      throws java.io.IOException, java.lang.ClassNotFoundException
    MethodParameters:
      Name  Flags
      s     

  public final java.util.Spliterator<E> spliterator();
    descriptor: ()Ljava/util/Spliterator;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=6, locals=1, args_size=1
        start local 0 // java.util.PriorityQueue this
         0: .line 813
            new java.util.PriorityQueue$PriorityQueueSpliterator
            dup
            aload 0 /* this */
            iconst_0
            iconst_m1
            iconst_0
            invokespecial java.util.PriorityQueue$PriorityQueueSpliterator.<init>:(Ljava/util/PriorityQueue;III)V
            areturn
        end local 0 // java.util.PriorityQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/util/PriorityQueue<TE;>;
    Signature: ()Ljava/util/Spliterator<TE;>;
}
Signature: <E:Ljava/lang/Object;>Ljava/util/AbstractQueue<TE;>;Ljava/io/Serializable;
SourceFile: "PriorityQueue.java"
NestMembers:
  java.util.PriorityQueue$Itr  java.util.PriorityQueue$PriorityQueueSpliterator
InnerClasses:
  private final Itr = java.util.PriorityQueue$Itr of java.util.PriorityQueue
  final PriorityQueueSpliterator = java.util.PriorityQueue$PriorityQueueSpliterator of java.util.PriorityQueue