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

  private final int capacity;
    descriptor: I
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

  transient java.util.concurrent.LinkedBlockingQueue$Node<E> head;
    descriptor: Ljava/util/concurrent/LinkedBlockingQueue$Node;
    flags: (0x0080) ACC_TRANSIENT
    Signature: Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;

  private transient java.util.concurrent.LinkedBlockingQueue$Node<E> last;
    descriptor: Ljava/util/concurrent/LinkedBlockingQueue$Node;
    flags: (0x0082) ACC_PRIVATE, ACC_TRANSIENT
    Signature: Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;

  private final java.util.concurrent.locks.ReentrantLock takeLock;
    descriptor: Ljava/util/concurrent/locks/ReentrantLock;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.locks.Condition notEmpty;
    descriptor: Ljava/util/concurrent/locks/Condition;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.locks.ReentrantLock putLock;
    descriptor: Ljava/util/concurrent/locks/ReentrantLock;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.locks.Condition notFull;
    descriptor: Ljava/util/concurrent/locks/Condition;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private void signalNotEmpty();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=3, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 174
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.takeLock:Ljava/util/concurrent/locks/ReentrantLock;
            astore 1 /* takeLock */
        start local 1 // java.util.concurrent.locks.ReentrantLock takeLock
         1: .line 175
            aload 1 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         2: .line 177
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notEmpty:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.signal:()V
         3: .line 178
            goto 7
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.concurrent.locks.ReentrantLock
      StackMap stack: java.lang.Throwable
         4: astore 2
         5: .line 179
            aload 1 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         6: .line 180
            aload 2
            athrow
         7: .line 179
      StackMap locals:
      StackMap stack:
            aload 1 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         8: .line 181
            return
        end local 1 // java.util.concurrent.locks.ReentrantLock takeLock
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    9     0      this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            1    9     1  takeLock  Ljava/util/concurrent/locks/ReentrantLock;
      Exception table:
        from    to  target  type
           2     4       4  any

  private void signalNotFull();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=3, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 187
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.putLock:Ljava/util/concurrent/locks/ReentrantLock;
            astore 1 /* putLock */
        start local 1 // java.util.concurrent.locks.ReentrantLock putLock
         1: .line 188
            aload 1 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         2: .line 190
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notFull:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.signal:()V
         3: .line 191
            goto 7
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.concurrent.locks.ReentrantLock
      StackMap stack: java.lang.Throwable
         4: astore 2
         5: .line 192
            aload 1 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         6: .line 193
            aload 2
            athrow
         7: .line 192
      StackMap locals:
      StackMap stack:
            aload 1 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         8: .line 194
            return
        end local 1 // java.util.concurrent.locks.ReentrantLock putLock
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    9     0     this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            1    9     1  putLock  Ljava/util/concurrent/locks/ReentrantLock;
      Exception table:
        from    to  target  type
           2     4       4  any

  private void enqueue(java.util.concurrent.LinkedBlockingQueue$Node<E>);
    descriptor: (Ljava/util/concurrent/LinkedBlockingQueue$Node;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.concurrent.LinkedBlockingQueue$Node node
         0: .line 204
            aload 0 /* this */
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.last:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            aload 1 /* node */
            dup_x1
            putfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            putfield java.util.concurrent.LinkedBlockingQueue.last:Ljava/util/concurrent/LinkedBlockingQueue$Node;
         1: .line 205
            return
        end local 1 // java.util.concurrent.LinkedBlockingQueue$Node node
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0    2     1  node  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
    Signature: (Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;)V
    MethodParameters:
      Name  Flags
      node  

  private E dequeue();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 215
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 1 /* h */
        start local 1 // java.util.concurrent.LinkedBlockingQueue$Node h
         1: .line 216
            aload 1 /* h */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 2 /* first */
        start local 2 // java.util.concurrent.LinkedBlockingQueue$Node first
         2: .line 217
            aload 1 /* h */
            aload 1 /* h */
            putfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
         3: .line 218
            aload 0 /* this */
            aload 2 /* first */
            putfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
         4: .line 219
            aload 2 /* first */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            astore 3 /* x */
        start local 3 // java.lang.Object x
         5: .line 220
            aload 2 /* first */
            aconst_null
            putfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
         6: .line 221
            aload 3 /* x */
            areturn
        end local 3 // java.lang.Object x
        end local 2 // java.util.concurrent.LinkedBlockingQueue$Node first
        end local 1 // java.util.concurrent.LinkedBlockingQueue$Node h
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    7     0   this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            1    7     1      h  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            2    7     2  first  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            5    7     3      x  TE;
    Signature: ()TE;

  void fullyLock();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 228
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.putLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         1: .line 229
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.takeLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         2: .line 230
            return
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;

  void fullyUnlock();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 236
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.takeLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         1: .line 237
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.putLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         2: .line 238
            return
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 245
            aload 0 /* this */
            ldc 2147483647
            invokespecial java.util.concurrent.LinkedBlockingQueue.<init>:(I)V
         1: .line 246
            return
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;

  public void <init>(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // int capacity
         0: .line 255
            aload 0 /* this */
            invokespecial java.util.AbstractQueue.<init>:()V
         1: .line 141
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicInteger
            dup
            invokespecial java.util.concurrent.atomic.AtomicInteger.<init>:()V
            putfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
         2: .line 156
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
            putfield java.util.concurrent.LinkedBlockingQueue.takeLock:Ljava/util/concurrent/locks/ReentrantLock;
         3: .line 160
            aload 0 /* this */
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.takeLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.newCondition:()Ljava/util/concurrent/locks/Condition;
            putfield java.util.concurrent.LinkedBlockingQueue.notEmpty:Ljava/util/concurrent/locks/Condition;
         4: .line 163
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
            putfield java.util.concurrent.LinkedBlockingQueue.putLock:Ljava/util/concurrent/locks/ReentrantLock;
         5: .line 167
            aload 0 /* this */
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.putLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.newCondition:()Ljava/util/concurrent/locks/Condition;
            putfield java.util.concurrent.LinkedBlockingQueue.notFull:Ljava/util/concurrent/locks/Condition;
         6: .line 256
            iload 1 /* capacity */
            ifgt 7
            new java.lang.IllegalArgumentException
            dup
            invokespecial java.lang.IllegalArgumentException.<init>:()V
            athrow
         7: .line 257
      StackMap locals: java.util.concurrent.LinkedBlockingQueue int
      StackMap stack:
            aload 0 /* this */
            iload 1 /* capacity */
            putfield java.util.concurrent.LinkedBlockingQueue.capacity:I
         8: .line 258
            aload 0 /* this */
            aload 0 /* this */
            new java.util.concurrent.LinkedBlockingQueue$Node
            dup
            aconst_null
            invokespecial java.util.concurrent.LinkedBlockingQueue$Node.<init>:(Ljava/lang/Object;)V
            dup_x1
            putfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            putfield java.util.concurrent.LinkedBlockingQueue.last:Ljava/util/concurrent/LinkedBlockingQueue$Node;
         9: .line 259
            return
        end local 1 // int capacity
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   10     0      this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   10     1  capacity  I
    MethodParameters:
          Name  Flags
      capacity  

  public void <init>(java.util.Collection<? extends E>);
    descriptor: (Ljava/util/Collection;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=7, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.Collection c
         0: .line 272
            aload 0 /* this */
            ldc 2147483647
            invokespecial java.util.concurrent.LinkedBlockingQueue.<init>:(I)V
         1: .line 273
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.putLock:Ljava/util/concurrent/locks/ReentrantLock;
            astore 2 /* putLock */
        start local 2 // java.util.concurrent.locks.ReentrantLock putLock
         2: .line 274
            aload 2 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         3: .line 276
            iconst_0
            istore 3 /* n */
        start local 3 // int n
         4: .line 277
            aload 1 /* c */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 5
            goto 12
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.Collection java.util.concurrent.locks.ReentrantLock int top java.util.Iterator
      StackMap stack:
         5: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.Object
            astore 4 /* e */
        start local 4 // java.lang.Object e
         6: .line 278
            aload 4 /* e */
            ifnonnull 8
         7: .line 279
            new java.lang.NullPointerException
            dup
            invokespecial java.lang.NullPointerException.<init>:()V
            athrow
         8: .line 280
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.Collection java.util.concurrent.locks.ReentrantLock int java.lang.Object java.util.Iterator
      StackMap stack:
            iload 3 /* n */
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpne 10
         9: .line 281
            new java.lang.IllegalStateException
            dup
            ldc "Queue full"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 282
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new java.util.concurrent.LinkedBlockingQueue$Node
            dup
            aload 4 /* e */
            invokespecial java.util.concurrent.LinkedBlockingQueue$Node.<init>:(Ljava/lang/Object;)V
            invokevirtual java.util.concurrent.LinkedBlockingQueue.enqueue:(Ljava/util/concurrent/LinkedBlockingQueue$Node;)V
        11: .line 283
            iinc 3 /* n */ 1
        end local 4 // java.lang.Object e
        12: .line 277
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.Collection java.util.concurrent.locks.ReentrantLock int top java.util.Iterator
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        13: .line 285
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            iload 3 /* n */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.set:(I)V
        end local 3 // int n
        14: .line 286
            goto 18
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.Collection java.util.concurrent.locks.ReentrantLock
      StackMap stack: java.lang.Throwable
        15: astore 6
        16: .line 287
            aload 2 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        17: .line 288
            aload 6
            athrow
        18: .line 287
      StackMap locals:
      StackMap stack:
            aload 2 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        19: .line 289
            return
        end local 2 // java.util.concurrent.locks.ReentrantLock putLock
        end local 1 // java.util.Collection c
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   20     0     this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   20     1        c  Ljava/util/Collection<+TE;>;
            2   20     2  putLock  Ljava/util/concurrent/locks/ReentrantLock;
            4   14     3        n  I
            6   12     4        e  TE;
      Exception table:
        from    to  target  type
           3    15      15  any
    Signature: (Ljava/util/Collection<+TE;>;)V
    MethodParameters:
      Name  Flags
      c     

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

  public int remainingCapacity();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 316
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            isub
            ireturn
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;

  public void put();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=7, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.lang.Object e
         0: .line 327
            aload 1 /* e */
            ifnonnull 1
            new java.lang.NullPointerException
            dup
            invokespecial java.lang.NullPointerException.<init>:()V
            athrow
         1: .line 329
      StackMap locals:
      StackMap stack:
            new java.util.concurrent.LinkedBlockingQueue$Node
            dup
            aload 1 /* e */
            invokespecial java.util.concurrent.LinkedBlockingQueue$Node.<init>:(Ljava/lang/Object;)V
            astore 3 /* node */
        start local 3 // java.util.concurrent.LinkedBlockingQueue$Node node
         2: .line 330
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.putLock:Ljava/util/concurrent/locks/ReentrantLock;
            astore 4 /* putLock */
        start local 4 // java.util.concurrent.locks.ReentrantLock putLock
         3: .line 331
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            astore 5 /* count */
        start local 5 // java.util.concurrent.atomic.AtomicInteger count
         4: .line 332
            aload 4 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.lockInterruptibly:()V
         5: .line 342
            goto 7
         6: .line 343
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.lang.Object top java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.locks.ReentrantLock java.util.concurrent.atomic.AtomicInteger
      StackMap stack:
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notFull:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.await:()V
         7: .line 342
      StackMap locals:
      StackMap stack:
            aload 5 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpeq 6
         8: .line 345
            aload 0 /* this */
            aload 3 /* node */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.enqueue:(Ljava/util/concurrent/LinkedBlockingQueue$Node;)V
         9: .line 346
            aload 5 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndIncrement:()I
            istore 2 /* c */
        start local 2 // int c
        10: .line 347
            iload 2 /* c */
            iconst_1
            iadd
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpge 16
        11: .line 348
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notFull:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.signal:()V
        12: .line 349
            goto 16
        end local 2 // int c
      StackMap locals:
      StackMap stack: java.lang.Throwable
        13: astore 6
        14: .line 350
            aload 4 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        15: .line 351
            aload 6
            athrow
        start local 2 // int c
        16: .line 350
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.lang.Object int java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.locks.ReentrantLock java.util.concurrent.atomic.AtomicInteger
      StackMap stack:
            aload 4 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        17: .line 352
            iload 2 /* c */
            ifne 19
        18: .line 353
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.signalNotEmpty:()V
        19: .line 354
      StackMap locals:
      StackMap stack:
            return
        end local 5 // java.util.concurrent.atomic.AtomicInteger count
        end local 4 // java.util.concurrent.locks.ReentrantLock putLock
        end local 3 // java.util.concurrent.LinkedBlockingQueue$Node node
        end local 2 // int c
        end local 1 // java.lang.Object e
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   20     0     this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   20     1        e  TE;
           10   13     2        c  I
           16   20     2        c  I
            2   20     3     node  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            3   20     4  putLock  Ljava/util/concurrent/locks/ReentrantLock;
            4   20     5    count  Ljava/util/concurrent/atomic/AtomicInteger;
      Exception table:
        from    to  target  type
           5    13      13  any
    Exceptions:
      throws java.lang.InterruptedException
    Signature: (TE;)V
    MethodParameters:
      Name  Flags
      e     

  public boolean offer(E, long, java.util.concurrent.TimeUnit);
    descriptor: (Ljava/lang/Object;JLjava/util/concurrent/TimeUnit;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=11, args_size=4
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.lang.Object e
        start local 2 // long timeout
        start local 4 // java.util.concurrent.TimeUnit unit
         0: .line 368
            aload 1 /* e */
            ifnonnull 1
            new java.lang.NullPointerException
            dup
            invokespecial java.lang.NullPointerException.<init>:()V
            athrow
         1: .line 369
      StackMap locals:
      StackMap stack:
            aload 4 /* unit */
            lload 2 /* timeout */
            invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
            lstore 5 /* nanos */
        start local 5 // long nanos
         2: .line 371
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.putLock:Ljava/util/concurrent/locks/ReentrantLock;
            astore 8 /* putLock */
        start local 8 // java.util.concurrent.locks.ReentrantLock putLock
         3: .line 372
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            astore 9 /* count */
        start local 9 // java.util.concurrent.atomic.AtomicInteger count
         4: .line 373
            aload 8 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.lockInterruptibly:()V
         5: .line 375
            goto 10
         6: .line 376
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.lang.Object long java.util.concurrent.TimeUnit long top java.util.concurrent.locks.ReentrantLock java.util.concurrent.atomic.AtomicInteger
      StackMap stack:
            lload 5 /* nanos */
            lconst_0
            lcmp
            ifgt 9
         7: .line 385
            aload 8 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         8: .line 377
            iconst_0
            ireturn
         9: .line 378
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notFull:Ljava/util/concurrent/locks/Condition;
            lload 5 /* nanos */
            invokeinterface java.util.concurrent.locks.Condition.awaitNanos:(J)J
            lstore 5 /* nanos */
        10: .line 375
      StackMap locals:
      StackMap stack:
            aload 9 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpeq 6
        11: .line 380
            aload 0 /* this */
            new java.util.concurrent.LinkedBlockingQueue$Node
            dup
            aload 1 /* e */
            invokespecial java.util.concurrent.LinkedBlockingQueue$Node.<init>:(Ljava/lang/Object;)V
            invokevirtual java.util.concurrent.LinkedBlockingQueue.enqueue:(Ljava/util/concurrent/LinkedBlockingQueue$Node;)V
        12: .line 381
            aload 9 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndIncrement:()I
            istore 7 /* c */
        start local 7 // int c
        13: .line 382
            iload 7 /* c */
            iconst_1
            iadd
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpge 19
        14: .line 383
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notFull:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.signal:()V
        15: .line 384
            goto 19
        end local 7 // int c
      StackMap locals:
      StackMap stack: java.lang.Throwable
        16: astore 10
        17: .line 385
            aload 8 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        18: .line 386
            aload 10
            athrow
        start local 7 // int c
        19: .line 385
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.lang.Object long java.util.concurrent.TimeUnit long int java.util.concurrent.locks.ReentrantLock java.util.concurrent.atomic.AtomicInteger
      StackMap stack:
            aload 8 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        20: .line 387
            iload 7 /* c */
            ifne 22
        21: .line 388
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.signalNotEmpty:()V
        22: .line 389
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 9 // java.util.concurrent.atomic.AtomicInteger count
        end local 8 // java.util.concurrent.locks.ReentrantLock putLock
        end local 7 // int c
        end local 5 // long nanos
        end local 4 // java.util.concurrent.TimeUnit unit
        end local 2 // long timeout
        end local 1 // java.lang.Object e
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   23     0     this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   23     1        e  TE;
            0   23     2  timeout  J
            0   23     4     unit  Ljava/util/concurrent/TimeUnit;
            2   23     5    nanos  J
           13   16     7        c  I
           19   23     7        c  I
            3   23     8  putLock  Ljava/util/concurrent/locks/ReentrantLock;
            4   23     9    count  Ljava/util/concurrent/atomic/AtomicInteger;
      Exception table:
        from    to  target  type
           5     7      16  any
           9    16      16  any
    Exceptions:
      throws java.lang.InterruptedException
    Signature: (TE;JLjava/util/concurrent/TimeUnit;)Z
    MethodParameters:
         Name  Flags
      e        
      timeout  
      unit     

  public boolean offer();
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=7, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.lang.Object e
         0: .line 404
            aload 1 /* e */
            ifnonnull 1
            new java.lang.NullPointerException
            dup
            invokespecial java.lang.NullPointerException.<init>:()V
            athrow
         1: .line 405
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            astore 2 /* count */
        start local 2 // java.util.concurrent.atomic.AtomicInteger count
         2: .line 406
            aload 2 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpne 4
         3: .line 407
            iconst_0
            ireturn
         4: .line 409
      StackMap locals: java.util.concurrent.atomic.AtomicInteger
      StackMap stack:
            new java.util.concurrent.LinkedBlockingQueue$Node
            dup
            aload 1 /* e */
            invokespecial java.util.concurrent.LinkedBlockingQueue$Node.<init>:(Ljava/lang/Object;)V
            astore 4 /* node */
        start local 4 // java.util.concurrent.LinkedBlockingQueue$Node node
         5: .line 410
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.putLock:Ljava/util/concurrent/locks/ReentrantLock;
            astore 5 /* putLock */
        start local 5 // java.util.concurrent.locks.ReentrantLock putLock
         6: .line 411
            aload 5 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         7: .line 413
            aload 2 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpne 10
         8: .line 420
            aload 5 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         9: .line 414
            iconst_0
            ireturn
        10: .line 415
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.lang.Object java.util.concurrent.atomic.AtomicInteger top java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.locks.ReentrantLock
      StackMap stack:
            aload 0 /* this */
            aload 4 /* node */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.enqueue:(Ljava/util/concurrent/LinkedBlockingQueue$Node;)V
        11: .line 416
            aload 2 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndIncrement:()I
            istore 3 /* c */
        start local 3 // int c
        12: .line 417
            iload 3 /* c */
            iconst_1
            iadd
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpge 18
        13: .line 418
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notFull:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.signal:()V
        14: .line 419
            goto 18
        end local 3 // int c
      StackMap locals:
      StackMap stack: java.lang.Throwable
        15: astore 6
        16: .line 420
            aload 5 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        17: .line 421
            aload 6
            athrow
        start local 3 // int c
        18: .line 420
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.lang.Object java.util.concurrent.atomic.AtomicInteger int java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.locks.ReentrantLock
      StackMap stack:
            aload 5 /* putLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        19: .line 422
            iload 3 /* c */
            ifne 21
        20: .line 423
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.signalNotEmpty:()V
        21: .line 424
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 5 // java.util.concurrent.locks.ReentrantLock putLock
        end local 4 // java.util.concurrent.LinkedBlockingQueue$Node node
        end local 3 // int c
        end local 2 // java.util.concurrent.atomic.AtomicInteger count
        end local 1 // java.lang.Object e
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   22     0     this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   22     1        e  TE;
            2   22     2    count  Ljava/util/concurrent/atomic/AtomicInteger;
           12   15     3        c  I
           18   22     3        c  I
            5   22     4     node  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            6   22     5  putLock  Ljava/util/concurrent/locks/ReentrantLock;
      Exception table:
        from    to  target  type
           7     8      15  any
          10    15      15  any
    Signature: (TE;)Z
    MethodParameters:
      Name  Flags
      e     

  public E take();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=6, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 430
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            astore 3 /* count */
        start local 3 // java.util.concurrent.atomic.AtomicInteger count
         1: .line 431
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.takeLock:Ljava/util/concurrent/locks/ReentrantLock;
            astore 4 /* takeLock */
        start local 4 // java.util.concurrent.locks.ReentrantLock takeLock
         2: .line 432
            aload 4 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.lockInterruptibly:()V
         3: .line 434
            goto 5
         4: .line 435
      StackMap locals: java.util.concurrent.LinkedBlockingQueue top top java.util.concurrent.atomic.AtomicInteger java.util.concurrent.locks.ReentrantLock
      StackMap stack:
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notEmpty:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.await:()V
         5: .line 434
      StackMap locals:
      StackMap stack:
            aload 3 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            ifeq 4
         6: .line 437
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.dequeue:()Ljava/lang/Object;
            astore 1 /* x */
        start local 1 // java.lang.Object x
         7: .line 438
            aload 3 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndDecrement:()I
            istore 2 /* c */
        start local 2 // int c
         8: .line 439
            iload 2 /* c */
            iconst_1
            if_icmple 14
         9: .line 440
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notEmpty:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.signal:()V
        10: .line 441
            goto 14
        end local 2 // int c
        end local 1 // java.lang.Object x
      StackMap locals:
      StackMap stack: java.lang.Throwable
        11: astore 5
        12: .line 442
            aload 4 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        13: .line 443
            aload 5
            athrow
        start local 1 // java.lang.Object x
        start local 2 // int c
        14: .line 442
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.lang.Object int java.util.concurrent.atomic.AtomicInteger java.util.concurrent.locks.ReentrantLock
      StackMap stack:
            aload 4 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        15: .line 444
            iload 2 /* c */
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpne 17
        16: .line 445
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.signalNotFull:()V
        17: .line 446
      StackMap locals:
      StackMap stack:
            aload 1 /* x */
            areturn
        end local 4 // java.util.concurrent.locks.ReentrantLock takeLock
        end local 3 // java.util.concurrent.atomic.AtomicInteger count
        end local 2 // int c
        end local 1 // java.lang.Object x
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   18     0      this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            7   11     1         x  TE;
           14   18     1         x  TE;
            8   11     2         c  I
           14   18     2         c  I
            1   18     3     count  Ljava/util/concurrent/atomic/AtomicInteger;
            2   18     4  takeLock  Ljava/util/concurrent/locks/ReentrantLock;
      Exception table:
        from    to  target  type
           3    11      11  any
    Exceptions:
      throws java.lang.InterruptedException
    Signature: ()TE;

  public E poll(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=11, args_size=3
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // long timeout
        start local 3 // java.util.concurrent.TimeUnit unit
         0: .line 452
            aload 3 /* unit */
            lload 1 /* timeout */
            invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
            lstore 6 /* nanos */
        start local 6 // long nanos
         1: .line 453
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            astore 8 /* count */
        start local 8 // java.util.concurrent.atomic.AtomicInteger count
         2: .line 454
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.takeLock:Ljava/util/concurrent/locks/ReentrantLock;
            astore 9 /* takeLock */
        start local 9 // java.util.concurrent.locks.ReentrantLock takeLock
         3: .line 455
            aload 9 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.lockInterruptibly:()V
         4: .line 457
            goto 9
         5: .line 458
      StackMap locals: java.util.concurrent.LinkedBlockingQueue long java.util.concurrent.TimeUnit top top long java.util.concurrent.atomic.AtomicInteger java.util.concurrent.locks.ReentrantLock
      StackMap stack:
            lload 6 /* nanos */
            lconst_0
            lcmp
            ifgt 8
         6: .line 467
            aload 9 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         7: .line 459
            aconst_null
            areturn
         8: .line 460
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notEmpty:Ljava/util/concurrent/locks/Condition;
            lload 6 /* nanos */
            invokeinterface java.util.concurrent.locks.Condition.awaitNanos:(J)J
            lstore 6 /* nanos */
         9: .line 457
      StackMap locals:
      StackMap stack:
            aload 8 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            ifeq 5
        10: .line 462
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.dequeue:()Ljava/lang/Object;
            astore 4 /* x */
        start local 4 // java.lang.Object x
        11: .line 463
            aload 8 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndDecrement:()I
            istore 5 /* c */
        start local 5 // int c
        12: .line 464
            iload 5 /* c */
            iconst_1
            if_icmple 18
        13: .line 465
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notEmpty:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.signal:()V
        14: .line 466
            goto 18
        end local 5 // int c
        end local 4 // java.lang.Object x
      StackMap locals:
      StackMap stack: java.lang.Throwable
        15: astore 10
        16: .line 467
            aload 9 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        17: .line 468
            aload 10
            athrow
        start local 4 // java.lang.Object x
        start local 5 // int c
        18: .line 467
      StackMap locals: java.util.concurrent.LinkedBlockingQueue long java.util.concurrent.TimeUnit java.lang.Object int long java.util.concurrent.atomic.AtomicInteger java.util.concurrent.locks.ReentrantLock
      StackMap stack:
            aload 9 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        19: .line 469
            iload 5 /* c */
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpne 21
        20: .line 470
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.signalNotFull:()V
        21: .line 471
      StackMap locals:
      StackMap stack:
            aload 4 /* x */
            areturn
        end local 9 // java.util.concurrent.locks.ReentrantLock takeLock
        end local 8 // java.util.concurrent.atomic.AtomicInteger count
        end local 6 // long nanos
        end local 5 // int c
        end local 4 // java.lang.Object x
        end local 3 // java.util.concurrent.TimeUnit unit
        end local 1 // long timeout
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   22     0      this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   22     1   timeout  J
            0   22     3      unit  Ljava/util/concurrent/TimeUnit;
           11   15     4         x  TE;
           18   22     4         x  TE;
           12   15     5         c  I
           18   22     5         c  I
            1   22     6     nanos  J
            2   22     8     count  Ljava/util/concurrent/atomic/AtomicInteger;
            3   22     9  takeLock  Ljava/util/concurrent/locks/ReentrantLock;
      Exception table:
        from    to  target  type
           4     6      15  any
           8    15      15  any
    Exceptions:
      throws java.lang.InterruptedException
    Signature: (JLjava/util/concurrent/TimeUnit;)TE;
    MethodParameters:
         Name  Flags
      timeout  
      unit     

  public E poll();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=6, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 475
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            astore 1 /* count */
        start local 1 // java.util.concurrent.atomic.AtomicInteger count
         1: .line 476
            aload 1 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            ifne 3
         2: .line 477
            aconst_null
            areturn
         3: .line 480
      StackMap locals: java.util.concurrent.atomic.AtomicInteger
      StackMap stack:
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.takeLock:Ljava/util/concurrent/locks/ReentrantLock;
            astore 4 /* takeLock */
        start local 4 // java.util.concurrent.locks.ReentrantLock takeLock
         4: .line 481
            aload 4 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         5: .line 483
            aload 1 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            ifne 8
         6: .line 490
            aload 4 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         7: .line 484
            aconst_null
            areturn
         8: .line 485
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.concurrent.atomic.AtomicInteger top top java.util.concurrent.locks.ReentrantLock
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.dequeue:()Ljava/lang/Object;
            astore 2 /* x */
        start local 2 // java.lang.Object x
         9: .line 486
            aload 1 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndDecrement:()I
            istore 3 /* c */
        start local 3 // int c
        10: .line 487
            iload 3 /* c */
            iconst_1
            if_icmple 16
        11: .line 488
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notEmpty:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.signal:()V
        12: .line 489
            goto 16
        end local 3 // int c
        end local 2 // java.lang.Object x
      StackMap locals:
      StackMap stack: java.lang.Throwable
        13: astore 5
        14: .line 490
            aload 4 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        15: .line 491
            aload 5
            athrow
        start local 2 // java.lang.Object x
        start local 3 // int c
        16: .line 490
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.concurrent.atomic.AtomicInteger java.lang.Object int java.util.concurrent.locks.ReentrantLock
      StackMap stack:
            aload 4 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        17: .line 492
            iload 3 /* c */
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpne 19
        18: .line 493
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.signalNotFull:()V
        19: .line 494
      StackMap locals:
      StackMap stack:
            aload 2 /* x */
            areturn
        end local 4 // java.util.concurrent.locks.ReentrantLock takeLock
        end local 3 // int c
        end local 2 // java.lang.Object x
        end local 1 // java.util.concurrent.atomic.AtomicInteger count
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   20     0      this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            1   20     1     count  Ljava/util/concurrent/atomic/AtomicInteger;
            9   13     2         x  TE;
           16   20     2         x  TE;
           10   13     3         c  I
           16   20     3         c  I
            4   20     4  takeLock  Ljava/util/concurrent/locks/ReentrantLock;
      Exception table:
        from    to  target  type
           5     6      13  any
           8    13      13  any
    Signature: ()TE;

  public E peek();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=5, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 498
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            astore 1 /* count */
        start local 1 // java.util.concurrent.atomic.AtomicInteger count
         1: .line 499
            aload 1 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            ifne 3
         2: .line 500
            aconst_null
            areturn
         3: .line 501
      StackMap locals: java.util.concurrent.atomic.AtomicInteger
      StackMap stack:
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.takeLock:Ljava/util/concurrent/locks/ReentrantLock;
            astore 2 /* takeLock */
        start local 2 // java.util.concurrent.locks.ReentrantLock takeLock
         4: .line 502
            aload 2 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         5: .line 504
            aload 1 /* count */
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            ifle 6
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            goto 7
      StackMap locals: java.util.concurrent.locks.ReentrantLock
      StackMap stack:
         6: aconst_null
      StackMap locals:
      StackMap stack: java.lang.Object
         7: astore 4
         8: .line 506
            aload 2 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         9: .line 504
            aload 4
            areturn
        10: .line 505
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 3
        11: .line 506
            aload 2 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        12: .line 507
            aload 3
            athrow
        end local 2 // java.util.concurrent.locks.ReentrantLock takeLock
        end local 1 // java.util.concurrent.atomic.AtomicInteger count
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   13     0      this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            1   13     1     count  Ljava/util/concurrent/atomic/AtomicInteger;
            4   13     2  takeLock  Ljava/util/concurrent/locks/ReentrantLock;
      Exception table:
        from    to  target  type
           5     8      10  any
    Signature: ()TE;

  void unlink(java.util.concurrent.LinkedBlockingQueue$Node<E>, java.util.concurrent.LinkedBlockingQueue$Node<E>);
    descriptor: (Ljava/util/concurrent/LinkedBlockingQueue$Node;Ljava/util/concurrent/LinkedBlockingQueue$Node;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.concurrent.LinkedBlockingQueue$Node p
        start local 2 // java.util.concurrent.LinkedBlockingQueue$Node pred
         0: .line 518
            aload 1 /* p */
            aconst_null
            putfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
         1: .line 519
            aload 2 /* pred */
            aload 1 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            putfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
         2: .line 520
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.last:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            aload 1 /* p */
            if_acmpne 4
         3: .line 521
            aload 0 /* this */
            aload 2 /* pred */
            putfield java.util.concurrent.LinkedBlockingQueue.last:Ljava/util/concurrent/LinkedBlockingQueue$Node;
         4: .line 522
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndDecrement:()I
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpne 6
         5: .line 523
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notFull:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.signal:()V
         6: .line 524
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.util.concurrent.LinkedBlockingQueue$Node pred
        end local 1 // java.util.concurrent.LinkedBlockingQueue$Node p
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0    7     1     p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            0    7     2  pred  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
    Signature: (Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;)V
    MethodParameters:
      Name  Flags
      p     
      pred  

  public boolean remove(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.lang.Object o
         0: .line 538
            aload 1 /* o */
            ifnonnull 1
            iconst_0
            ireturn
         1: .line 539
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyLock:()V
         2: .line 541
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 2 /* pred */
        start local 2 // java.util.concurrent.LinkedBlockingQueue$Node pred
         3: aload 2 /* pred */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 3 /* p */
        start local 3 // java.util.concurrent.LinkedBlockingQueue$Node p
         4: .line 542
            goto 10
         5: .line 544
      StackMap locals: java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.LinkedBlockingQueue$Node
      StackMap stack:
            aload 1 /* o */
            aload 3 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 9
         6: .line 545
            aload 0 /* this */
            aload 3 /* p */
            aload 2 /* pred */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.unlink:(Ljava/util/concurrent/LinkedBlockingQueue$Node;Ljava/util/concurrent/LinkedBlockingQueue$Node;)V
         7: .line 551
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
         8: .line 546
            iconst_1
            ireturn
         9: .line 543
      StackMap locals:
      StackMap stack:
            aload 3 /* p */
            astore 2 /* pred */
            aload 3 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 3 /* p */
        10: .line 542
      StackMap locals:
      StackMap stack:
            aload 3 /* p */
            ifnonnull 5
        end local 3 // java.util.concurrent.LinkedBlockingQueue$Node p
        end local 2 // java.util.concurrent.LinkedBlockingQueue$Node pred
        11: .line 551
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        12: .line 549
            iconst_0
            ireturn
        13: .line 550
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.lang.Object
      StackMap stack: java.lang.Throwable
            astore 4
        14: .line 551
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        15: .line 552
            aload 4
            athrow
        end local 1 // java.lang.Object o
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   16     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   16     1     o  Ljava/lang/Object;
            3   11     2  pred  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            4   11     3     p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
      Exception table:
        from    to  target  type
           2     7      13  any
           9    11      13  any
    MethodParameters:
      Name  Flags
      o     

  public boolean contains(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.lang.Object o
         0: .line 564
            aload 1 /* o */
            ifnonnull 1
            iconst_0
            ireturn
         1: .line 565
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyLock:()V
         2: .line 567
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 2 /* p */
        start local 2 // java.util.concurrent.LinkedBlockingQueue$Node p
         3: goto 8
         4: .line 568
      StackMap locals: java.util.concurrent.LinkedBlockingQueue$Node
      StackMap stack:
            aload 1 /* o */
            aload 2 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 7
         5: .line 572
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
         6: .line 569
            iconst_1
            ireturn
         7: .line 567
      StackMap locals:
      StackMap stack:
            aload 2 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 2 /* p */
      StackMap locals:
      StackMap stack:
         8: aload 2 /* p */
            ifnonnull 4
        end local 2 // java.util.concurrent.LinkedBlockingQueue$Node p
         9: .line 572
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        10: .line 570
            iconst_0
            ireturn
        11: .line 571
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.lang.Object
      StackMap stack: java.lang.Throwable
            astore 3
        12: .line 572
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        13: .line 573
            aload 3
            athrow
        end local 1 // java.lang.Object o
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   14     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   14     1     o  Ljava/lang/Object;
            3    9     2     p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
      Exception table:
        from    to  target  type
           2     5      11  any
           7     9      11  any
    MethodParameters:
      Name  Flags
      o     

  public java.lang.Object[] toArray();
    descriptor: ()[Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=7, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 590
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyLock:()V
         1: .line 592
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            istore 1 /* size */
        start local 1 // int size
         2: .line 593
            iload 1 /* size */
            anewarray java.lang.Object
            astore 2 /* a */
        start local 2 // java.lang.Object[] a
         3: .line 594
            iconst_0
            istore 3 /* k */
        start local 3 // int k
         4: .line 595
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 4 /* p */
        start local 4 // java.util.concurrent.LinkedBlockingQueue$Node p
         5: goto 8
         6: .line 596
      StackMap locals: java.util.concurrent.LinkedBlockingQueue int java.lang.Object[] int java.util.concurrent.LinkedBlockingQueue$Node
      StackMap stack:
            aload 2 /* a */
            iload 3 /* k */
            iinc 3 /* k */ 1
            aload 4 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            aastore
         7: .line 595
            aload 4 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 4 /* p */
      StackMap locals:
      StackMap stack:
         8: aload 4 /* p */
            ifnonnull 6
        end local 4 // java.util.concurrent.LinkedBlockingQueue$Node p
         9: .line 597
            aload 2 /* a */
            astore 6
        10: .line 599
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        11: .line 597
            aload 6
            areturn
        end local 3 // int k
        end local 2 // java.lang.Object[] a
        end local 1 // int size
        12: .line 598
      StackMap locals: java.util.concurrent.LinkedBlockingQueue
      StackMap stack: java.lang.Throwable
            astore 5
        13: .line 599
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        14: .line 600
            aload 5
            athrow
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   15     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            2   12     1  size  I
            3   12     2     a  [Ljava/lang/Object;
            4   12     3     k  I
            5    9     4     p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
      Exception table:
        from    to  target  type
           1    10      12  any

  public <T> T[] toArray();
    descriptor: ([Ljava/lang/Object;)[Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=7, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.lang.Object[] a
         0: .line 640
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyLock:()V
         1: .line 642
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            istore 2 /* size */
        start local 2 // int size
         2: .line 643
            aload 1 /* a */
            arraylength
            iload 2 /* size */
            if_icmpge 5
         3: .line 645
            aload 1 /* a */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getComponentType:()Ljava/lang/Class;
            iload 2 /* size */
         4: .line 644
            invokestatic java.lang.reflect.Array.newInstance:(Ljava/lang/Class;I)Ljava/lang/Object;
            checkcast java.lang.Object[]
            astore 1 /* a */
         5: .line 647
      StackMap locals: int
      StackMap stack:
            iconst_0
            istore 3 /* k */
        start local 3 // int k
         6: .line 648
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 4 /* p */
        start local 4 // java.util.concurrent.LinkedBlockingQueue$Node p
         7: goto 10
         8: .line 649
      StackMap locals: int java.util.concurrent.LinkedBlockingQueue$Node
      StackMap stack:
            aload 1 /* a */
            iload 3 /* k */
            iinc 3 /* k */ 1
            aload 4 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            aastore
         9: .line 648
            aload 4 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 4 /* p */
      StackMap locals:
      StackMap stack:
        10: aload 4 /* p */
            ifnonnull 8
        end local 4 // java.util.concurrent.LinkedBlockingQueue$Node p
        11: .line 650
            aload 1 /* a */
            arraylength
            iload 3 /* k */
            if_icmple 13
        12: .line 651
            aload 1 /* a */
            iload 3 /* k */
            aconst_null
            aastore
        13: .line 652
      StackMap locals:
      StackMap stack:
            aload 1 /* a */
            astore 6
        14: .line 654
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        15: .line 652
            aload 6
            areturn
        end local 3 // int k
        end local 2 // int size
        16: .line 653
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.lang.Object[]
      StackMap stack: java.lang.Throwable
            astore 5
        17: .line 654
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        18: .line 655
            aload 5
            athrow
        end local 1 // java.lang.Object[] a
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   19     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   19     1     a  [Ljava/lang/Object;
            2   16     2  size  I
            6   16     3     k  I
            7   11     4     p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
      Exception table:
        from    to  target  type
           1    14      16  any
    Signature: <T:Ljava/lang/Object;>([TT;)[TT;
    MethodParameters:
      Name  Flags
      a     

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 659
            aload 0 /* this */
            invokestatic java.util.concurrent.Helpers.collectionToString:(Ljava/util/Collection;)Ljava/lang/String;
            areturn
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;

  public void clear();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
         0: .line 667
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyLock:()V
         1: .line 669
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 2 /* h */
        start local 2 // java.util.concurrent.LinkedBlockingQueue$Node h
         2: goto 6
        start local 1 // java.util.concurrent.LinkedBlockingQueue$Node p
         3: .line 670
      StackMap locals: java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.LinkedBlockingQueue$Node
      StackMap stack:
            aload 2 /* h */
            aload 2 /* h */
            putfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
         4: .line 671
            aload 1 /* p */
            aconst_null
            putfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
         5: .line 669
            aload 1 /* p */
            astore 2 /* h */
        end local 1 // java.util.concurrent.LinkedBlockingQueue$Node p
      StackMap locals: java.util.concurrent.LinkedBlockingQueue top java.util.concurrent.LinkedBlockingQueue$Node
      StackMap stack:
         6: aload 2 /* h */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            dup
            astore 1 /* p */
        start local 1 // java.util.concurrent.LinkedBlockingQueue$Node p
         7: ifnonnull 3
        end local 2 // java.util.concurrent.LinkedBlockingQueue$Node h
        end local 1 // java.util.concurrent.LinkedBlockingQueue$Node p
         8: .line 673
            aload 0 /* this */
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.last:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            putfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
         9: .line 675
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            iconst_0
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndSet:(I)I
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpne 15
        10: .line 676
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.notFull:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.signal:()V
        11: .line 677
            goto 15
      StackMap locals: java.util.concurrent.LinkedBlockingQueue
      StackMap stack: java.lang.Throwable
        12: astore 3
        13: .line 678
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        14: .line 679
            aload 3
            athrow
        15: .line 678
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        16: .line 680
            return
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   17     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            3    6     1     p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            7    8     1     p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            2    8     2     h  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
      Exception table:
        from    to  target  type
           1    12      12  any

  public int drainTo(java.util.Collection<? super E>);
    descriptor: (Ljava/util/Collection;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.Collection c
         0: .line 689
            aload 0 /* this */
            aload 1 /* c */
            ldc 2147483647
            invokevirtual java.util.concurrent.LinkedBlockingQueue.drainTo:(Ljava/util/Collection;I)I
            ireturn
        end local 1 // java.util.Collection c
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0    1     1     c  Ljava/util/Collection<-TE;>;
    Signature: (Ljava/util/Collection<-TE;>;)I
    MethodParameters:
      Name  Flags
      c     

  public int drainTo(java.util.Collection<? super E>, );
    descriptor: (Ljava/util/Collection;I)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=12, args_size=3
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.Collection c
        start local 2 // int maxElements
         0: .line 699
            aload 1 /* c */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 700
            aload 1 /* c */
            aload 0 /* this */
            if_acmpne 3
         2: .line 701
            new java.lang.IllegalArgumentException
            dup
            invokespecial java.lang.IllegalArgumentException.<init>:()V
            athrow
         3: .line 702
      StackMap locals:
      StackMap stack:
            iload 2 /* maxElements */
            ifgt 5
         4: .line 703
            iconst_0
            ireturn
         5: .line 704
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 3 /* signalNotFull */
        start local 3 // boolean signalNotFull
         6: .line 705
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.takeLock:Ljava/util/concurrent/locks/ReentrantLock;
            astore 4 /* takeLock */
        start local 4 // java.util.concurrent.locks.ReentrantLock takeLock
         7: .line 706
            aload 4 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         8: .line 708
            iload 2 /* maxElements */
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            invokestatic java.lang.Math.min:(II)I
            istore 5 /* n */
        start local 5 // int n
         9: .line 710
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 6 /* h */
        start local 6 // java.util.concurrent.LinkedBlockingQueue$Node h
        10: .line 711
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        11: .line 713
            goto 18
        12: .line 714
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.Collection int int java.util.concurrent.locks.ReentrantLock int java.util.concurrent.LinkedBlockingQueue$Node int
      StackMap stack:
            aload 6 /* h */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 8 /* p */
        start local 8 // java.util.concurrent.LinkedBlockingQueue$Node p
        13: .line 715
            aload 1 /* c */
            aload 8 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
            pop
        14: .line 716
            aload 8 /* p */
            aconst_null
            putfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
        15: .line 717
            aload 6 /* h */
            aload 6 /* h */
            putfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
        16: .line 718
            aload 8 /* p */
            astore 6 /* h */
        17: .line 719
            iinc 7 /* i */ 1
        end local 8 // java.util.concurrent.LinkedBlockingQueue$Node p
        18: .line 713
      StackMap locals:
      StackMap stack:
            iload 7 /* i */
            iload 5 /* n */
            if_icmplt 12
        19: .line 721
            iload 5 /* n */
            istore 10
        20: .line 724
            iload 7 /* i */
            ifle 25
        21: .line 726
            aload 0 /* this */
            aload 6 /* h */
            putfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
        22: .line 727
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            iload 7 /* i */
            ineg
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndAdd:(I)I
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpne 23
            iconst_1
            goto 24
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.Collection int int java.util.concurrent.locks.ReentrantLock int java.util.concurrent.LinkedBlockingQueue$Node int top top int
      StackMap stack:
        23: iconst_0
      StackMap locals:
      StackMap stack: int
        24: istore 3 /* signalNotFull */
        25: .line 731
      StackMap locals:
      StackMap stack:
            aload 4 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        26: .line 732
            iload 3 /* signalNotFull */
            ifeq 28
        27: .line 733
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.signalNotFull:()V
        28: .line 721
      StackMap locals:
      StackMap stack:
            iload 10
            ireturn
        29: .line 722
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.Collection int int java.util.concurrent.locks.ReentrantLock int java.util.concurrent.LinkedBlockingQueue$Node int
      StackMap stack: java.lang.Throwable
            astore 9
        30: .line 724
            iload 7 /* i */
            ifle 35
        31: .line 726
            aload 0 /* this */
            aload 6 /* h */
            putfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
        32: .line 727
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            iload 7 /* i */
            ineg
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndAdd:(I)I
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.capacity:I
            if_icmpne 33
            iconst_1
            goto 34
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.Collection int int java.util.concurrent.locks.ReentrantLock int java.util.concurrent.LinkedBlockingQueue$Node int top java.lang.Throwable
      StackMap stack:
        33: iconst_0
      StackMap locals:
      StackMap stack: int
        34: istore 3 /* signalNotFull */
        35: .line 729
      StackMap locals:
      StackMap stack:
            aload 9
            athrow
        end local 7 // int i
        end local 6 // java.util.concurrent.LinkedBlockingQueue$Node h
        end local 5 // int n
        36: .line 730
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.Collection int int java.util.concurrent.locks.ReentrantLock
      StackMap stack: java.lang.Throwable
            astore 11
        37: .line 731
            aload 4 /* takeLock */
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        38: .line 732
            iload 3 /* signalNotFull */
            ifeq 40
        39: .line 733
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.signalNotFull:()V
        40: .line 734
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.Collection int int java.util.concurrent.locks.ReentrantLock top top top top top top java.lang.Throwable
      StackMap stack:
            aload 11
            athrow
        end local 4 // java.util.concurrent.locks.ReentrantLock takeLock
        end local 3 // boolean signalNotFull
        end local 2 // int maxElements
        end local 1 // java.util.Collection c
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   41     0           this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   41     1              c  Ljava/util/Collection<-TE;>;
            0   41     2    maxElements  I
            6   41     3  signalNotFull  Z
            7   41     4       takeLock  Ljava/util/concurrent/locks/ReentrantLock;
            9   36     5              n  I
           10   36     6              h  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
           11   36     7              i  I
           13   18     8              p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
      Exception table:
        from    to  target  type
          11    20      29  any
           8    25      36  any
          29    36      36  any
    Signature: (Ljava/util/Collection<-TE;>;I)I
    MethodParameters:
             Name  Flags
      c            
      maxElements  

  java.util.concurrent.LinkedBlockingQueue$Node<E> succ(java.util.concurrent.LinkedBlockingQueue$Node<E>);
    descriptor: (Ljava/util/concurrent/LinkedBlockingQueue$Node;)Ljava/util/concurrent/LinkedBlockingQueue$Node;
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.concurrent.LinkedBlockingQueue$Node p
         0: .line 744
            aload 1 /* p */
            aload 1 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            dup
            astore 1 /* p */
            if_acmpne 2
         1: .line 745
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 1 /* p */
         2: .line 746
      StackMap locals:
      StackMap stack:
            aload 1 /* p */
            areturn
        end local 1 // java.util.concurrent.LinkedBlockingQueue$Node p
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0    3     1     p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
    Signature: (Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;)Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
    MethodParameters:
      Name  Flags
      p     

  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.concurrent.LinkedBlockingQueue this
         0: .line 759
            new java.util.concurrent.LinkedBlockingQueue$Itr
            dup
            aload 0 /* this */
            invokespecial java.util.concurrent.LinkedBlockingQueue$Itr.<init>:(Ljava/util/concurrent/LinkedBlockingQueue;)V
            areturn
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
    Signature: ()Ljava/util/Iterator<TE;>;

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

  public void forEach(java.util.function.Consumer<? super E>);
    descriptor: (Ljava/util/function/Consumer;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.function.Consumer action
         0: .line 980
            aload 1 /* action */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 981
            aload 0 /* this */
            aload 1 /* action */
            aconst_null
            invokevirtual java.util.concurrent.LinkedBlockingQueue.forEachFrom:(Ljava/util/function/Consumer;Ljava/util/concurrent/LinkedBlockingQueue$Node;)V
         2: .line 982
            return
        end local 1 // java.util.function.Consumer action
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0    3     1  action  Ljava/util/function/Consumer<-TE;>;
    Signature: (Ljava/util/function/Consumer<-TE;>;)V
    MethodParameters:
        Name  Flags
      action  

  void forEachFrom(java.util.function.Consumer<? super E>, java.util.concurrent.LinkedBlockingQueue$Node<E>);
    descriptor: (Ljava/util/function/Consumer;Ljava/util/concurrent/LinkedBlockingQueue$Node;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=8, args_size=3
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.function.Consumer action
        start local 2 // java.util.concurrent.LinkedBlockingQueue$Node p
         0: .line 992
            aconst_null
            astore 3 /* es */
        start local 3 // java.lang.Object[] es
         1: .line 993
            iconst_0
            istore 5 /* len */
        start local 5 // int len
         2: .line 995
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.function.Consumer java.util.concurrent.LinkedBlockingQueue$Node java.lang.Object[] top int
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyLock:()V
         3: .line 997
            aload 3 /* es */
            ifnonnull 12
         4: .line 998
            aload 2 /* p */
            ifnonnull 5
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 2 /* p */
         5: .line 999
      StackMap locals:
      StackMap stack:
            aload 2 /* p */
            astore 6 /* q */
        start local 6 // java.util.concurrent.LinkedBlockingQueue$Node q
         6: goto 10
         7: .line 1000
      StackMap locals: java.util.concurrent.LinkedBlockingQueue$Node
      StackMap stack:
            aload 6 /* q */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            ifnull 9
            iinc 5 /* len */ 1
            iload 5 /* len */
            bipush 64
            if_icmpne 9
         8: .line 1001
            goto 11
         9: .line 999
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 6 /* q */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.succ:(Ljava/util/concurrent/LinkedBlockingQueue$Node;)Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 6 /* q */
      StackMap locals:
      StackMap stack:
        10: aload 6 /* q */
            ifnonnull 7
        end local 6 // java.util.concurrent.LinkedBlockingQueue$Node q
        11: .line 1002
      StackMap locals:
      StackMap stack:
            iload 5 /* len */
            anewarray java.lang.Object
            astore 3 /* es */
        12: .line 1004
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 4 /* n */
        start local 4 // int n
        13: goto 17
        14: .line 1005
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.function.Consumer java.util.concurrent.LinkedBlockingQueue$Node java.lang.Object[] int int
      StackMap stack:
            aload 3 /* es */
            iload 4 /* n */
            aload 2 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            dup_x2
            aastore
            ifnull 16
        15: .line 1006
            iinc 4 /* n */ 1
        16: .line 1004
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* p */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.succ:(Ljava/util/concurrent/LinkedBlockingQueue$Node;)Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 2 /* p */
      StackMap locals:
      StackMap stack:
        17: aload 2 /* p */
            ifnull 22
            iload 4 /* n */
            iload 5 /* len */
            if_icmplt 14
        18: .line 1007
            goto 22
        end local 4 // int n
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.function.Consumer java.util.concurrent.LinkedBlockingQueue$Node java.lang.Object[] top int
      StackMap stack: java.lang.Throwable
        19: astore 7
        20: .line 1008
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        21: .line 1009
            aload 7
            athrow
        start local 4 // int n
        22: .line 1008
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.function.Consumer java.util.concurrent.LinkedBlockingQueue$Node java.lang.Object[] int int
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        23: .line 1010
            iconst_0
            istore 6 /* i */
        start local 6 // int i
        24: goto 28
        25: .line 1011
      StackMap locals: int
      StackMap stack:
            aload 3 /* es */
            iload 6 /* i */
            aaload
            astore 7 /* e */
        start local 7 // java.lang.Object e
        26: .line 1012
            aload 1 /* action */
            aload 7 /* e */
            invokeinterface java.util.function.Consumer.accept:(Ljava/lang/Object;)V
        end local 7 // java.lang.Object e
        27: .line 1010
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        28: iload 6 /* i */
            iload 4 /* n */
            if_icmplt 25
        end local 6 // int i
        29: .line 1014
            iload 4 /* n */
            ifle 30
            aload 2 /* p */
            ifnonnull 2
        30: .line 1015
      StackMap locals:
      StackMap stack:
            return
        end local 5 // int len
        end local 4 // int n
        end local 3 // java.lang.Object[] es
        end local 2 // java.util.concurrent.LinkedBlockingQueue$Node p
        end local 1 // java.util.function.Consumer action
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   31     0    this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   31     1  action  Ljava/util/function/Consumer<-TE;>;
            0   31     2       p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            1   31     3      es  [Ljava/lang/Object;
           13   19     4       n  I
           22   31     4       n  I
            2   31     5     len  I
            6   11     6       q  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
           24   29     6       i  I
           26   27     7       e  TE;
      Exception table:
        from    to  target  type
           3    19      19  any
    Signature: (Ljava/util/function/Consumer<-TE;>;Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;)V
    MethodParameters:
        Name  Flags
      action  
      p       

  public boolean removeIf(java.util.function.Predicate<? super E>);
    descriptor: (Ljava/util/function/Predicate;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.function.Predicate filter
         0: .line 1021
            aload 1 /* filter */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 1022
            aload 0 /* this */
            aload 1 /* filter */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.bulkRemove:(Ljava/util/function/Predicate;)Z
            ireturn
        end local 1 // java.util.function.Predicate filter
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0    2     1  filter  Ljava/util/function/Predicate<-TE;>;
    Signature: (Ljava/util/function/Predicate<-TE;>;)Z
    MethodParameters:
        Name  Flags
      filter  

  public boolean removeAll(java.util.Collection<?>);
    descriptor: (Ljava/util/Collection;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.Collection c
         0: .line 1029
            aload 1 /* c */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 1030
            aload 0 /* this */
            aload 1 /* c */
            invokedynamic test(Ljava/util/Collection;)Ljava/util/function/Predicate;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)Z
                  java/util/concurrent/LinkedBlockingQueue.lambda$0(Ljava/util/Collection;Ljava/lang/Object;)Z (6)
                  (Ljava/lang/Object;)Z
            invokevirtual java.util.concurrent.LinkedBlockingQueue.bulkRemove:(Ljava/util/function/Predicate;)Z
            ireturn
        end local 1 // java.util.Collection c
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0    2     1     c  Ljava/util/Collection<*>;
    Signature: (Ljava/util/Collection<*>;)Z
    MethodParameters:
      Name  Flags
      c     

  public boolean retainAll(java.util.Collection<?>);
    descriptor: (Ljava/util/Collection;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.Collection c
         0: .line 1037
            aload 1 /* c */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 1038
            aload 0 /* this */
            aload 1 /* c */
            invokedynamic test(Ljava/util/Collection;)Ljava/util/function/Predicate;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)Z
                  java/util/concurrent/LinkedBlockingQueue.lambda$1(Ljava/util/Collection;Ljava/lang/Object;)Z (6)
                  (Ljava/lang/Object;)Z
            invokevirtual java.util.concurrent.LinkedBlockingQueue.bulkRemove:(Ljava/util/function/Predicate;)Z
            ireturn
        end local 1 // java.util.Collection c
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0    2     1     c  Ljava/util/Collection<*>;
    Signature: (Ljava/util/Collection<*>;)Z
    MethodParameters:
      Name  Flags
      c     

  java.util.concurrent.LinkedBlockingQueue$Node<E> findPred(java.util.concurrent.LinkedBlockingQueue$Node<E>, java.util.concurrent.LinkedBlockingQueue$Node<E>);
    descriptor: (Ljava/util/concurrent/LinkedBlockingQueue$Node;Ljava/util/concurrent/LinkedBlockingQueue$Node;)Ljava/util/concurrent/LinkedBlockingQueue$Node;
    flags: (0x0000) 
    Code:
      stack=2, locals=4, args_size=3
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.concurrent.LinkedBlockingQueue$Node p
        start local 2 // java.util.concurrent.LinkedBlockingQueue$Node ancestor
         0: .line 1047
            aload 2 /* ancestor */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            ifnonnull 4
         1: .line 1048
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 2 /* ancestor */
         2: .line 1050
            goto 4
        start local 3 // java.util.concurrent.LinkedBlockingQueue$Node q
         3: .line 1051
      StackMap locals: java.util.concurrent.LinkedBlockingQueue$Node
      StackMap stack:
            aload 3 /* q */
            astore 2 /* ancestor */
        end local 3 // java.util.concurrent.LinkedBlockingQueue$Node q
         4: .line 1050
      StackMap locals:
      StackMap stack:
            aload 2 /* ancestor */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            dup
            astore 3 /* q */
        start local 3 // java.util.concurrent.LinkedBlockingQueue$Node q
         5: aload 1 /* p */
            if_acmpne 3
        end local 3 // java.util.concurrent.LinkedBlockingQueue$Node q
         6: .line 1052
            aload 2 /* ancestor */
            areturn
        end local 2 // java.util.concurrent.LinkedBlockingQueue$Node ancestor
        end local 1 // java.util.concurrent.LinkedBlockingQueue$Node p
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0    7     1         p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            0    7     2  ancestor  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            3    4     3         q  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            5    6     3         q  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
    Signature: (Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;)Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
    MethodParameters:
          Name  Flags
      p         
      ancestor  

  private boolean bulkRemove(java.util.function.Predicate<? super E>);
    descriptor: (Ljava/util/function/Predicate;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=13, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.util.function.Predicate filter
         0: .line 1058
            iconst_0
            istore 2 /* removed */
        start local 2 // boolean removed
         1: .line 1059
            aconst_null
            astore 3 /* p */
        start local 3 // java.util.concurrent.LinkedBlockingQueue$Node p
         2: aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 4 /* ancestor */
        start local 4 // java.util.concurrent.LinkedBlockingQueue$Node ancestor
         3: .line 1060
            aconst_null
            astore 5 /* nodes */
        start local 5 // java.util.concurrent.LinkedBlockingQueue$Node[] nodes
         4: .line 1061
            iconst_0
            istore 7 /* len */
        start local 7 // int len
         5: .line 1064
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.function.Predicate int java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.LinkedBlockingQueue$Node[] top int
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyLock:()V
         6: .line 1066
            aload 5 /* nodes */
            ifnonnull 15
         7: .line 1067
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 3 /* p */
         8: .line 1068
            aload 3 /* p */
            astore 8 /* q */
        start local 8 // java.util.concurrent.LinkedBlockingQueue$Node q
         9: goto 13
        10: .line 1069
      StackMap locals: java.util.concurrent.LinkedBlockingQueue$Node
      StackMap stack:
            aload 8 /* q */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            ifnull 12
            iinc 7 /* len */ 1
            iload 7 /* len */
            bipush 64
            if_icmpne 12
        11: .line 1070
            goto 14
        12: .line 1068
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 8 /* q */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.succ:(Ljava/util/concurrent/LinkedBlockingQueue$Node;)Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 8 /* q */
      StackMap locals:
      StackMap stack:
        13: aload 8 /* q */
            ifnonnull 10
        end local 8 // java.util.concurrent.LinkedBlockingQueue$Node q
        14: .line 1071
      StackMap locals:
      StackMap stack:
            iload 7 /* len */
            anewarray java.util.concurrent.LinkedBlockingQueue$Node
            astore 5 /* nodes */
        15: .line 1073
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 6 /* n */
        start local 6 // int n
        16: goto 19
        17: .line 1074
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.function.Predicate int java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.LinkedBlockingQueue$Node[] int int
      StackMap stack:
            aload 5 /* nodes */
            iload 6 /* n */
            iinc 6 /* n */ 1
            aload 3 /* p */
            aastore
        18: .line 1073
            aload 0 /* this */
            aload 3 /* p */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.succ:(Ljava/util/concurrent/LinkedBlockingQueue$Node;)Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 3 /* p */
      StackMap locals:
      StackMap stack:
        19: aload 3 /* p */
            ifnull 24
            iload 6 /* n */
            iload 7 /* len */
            if_icmplt 17
        20: .line 1075
            goto 24
        end local 6 // int n
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.function.Predicate int java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.LinkedBlockingQueue$Node[] top int
      StackMap stack: java.lang.Throwable
        21: astore 9
        22: .line 1076
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        23: .line 1077
            aload 9
            athrow
        start local 6 // int n
        24: .line 1076
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.function.Predicate int java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.LinkedBlockingQueue$Node[] int int
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        25: .line 1080
            lconst_0
            lstore 8 /* deathRow */
        start local 8 // long deathRow
        26: .line 1081
            iconst_0
            istore 10 /* i */
        start local 10 // int i
        27: goto 32
        28: .line 1083
      StackMap locals: long int
      StackMap stack:
            aload 5 /* nodes */
            iload 10 /* i */
            aaload
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            dup
            astore 11 /* e */
        start local 11 // java.lang.Object e
        29: ifnull 31
            aload 1 /* filter */
            aload 11 /* e */
            invokeinterface java.util.function.Predicate.test:(Ljava/lang/Object;)Z
            ifeq 31
        30: .line 1084
            lload 8 /* deathRow */
            lconst_1
            iload 10 /* i */
            lshl
            lor
            lstore 8 /* deathRow */
        end local 11 // java.lang.Object e
        31: .line 1081
      StackMap locals:
      StackMap stack:
            iinc 10 /* i */ 1
      StackMap locals:
      StackMap stack:
        32: iload 10 /* i */
            iload 6 /* n */
            if_icmplt 28
        end local 10 // int i
        33: .line 1088
            lload 8 /* deathRow */
            lconst_0
            lcmp
            ifeq 51
        34: .line 1089
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyLock:()V
        35: .line 1091
            iconst_0
            istore 10 /* i */
        start local 10 // int i
        36: goto 45
        37: .line 1093
      StackMap locals:
      StackMap stack:
            lload 8 /* deathRow */
            lconst_1
            iload 10 /* i */
            lshl
            land
            lconst_0
            lcmp
            ifeq 43
        38: .line 1094
            aload 5 /* nodes */
            iload 10 /* i */
            aaload
            dup
            astore 11 /* q */
        start local 11 // java.util.concurrent.LinkedBlockingQueue$Node q
        39: getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            ifnull 43
        40: .line 1095
            aload 0 /* this */
            aload 11 /* q */
            aload 4 /* ancestor */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.findPred:(Ljava/util/concurrent/LinkedBlockingQueue$Node;Ljava/util/concurrent/LinkedBlockingQueue$Node;)Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 4 /* ancestor */
        41: .line 1096
            aload 0 /* this */
            aload 11 /* q */
            aload 4 /* ancestor */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.unlink:(Ljava/util/concurrent/LinkedBlockingQueue$Node;Ljava/util/concurrent/LinkedBlockingQueue$Node;)V
        42: .line 1097
            iconst_1
            istore 2 /* removed */
        end local 11 // java.util.concurrent.LinkedBlockingQueue$Node q
        43: .line 1099
      StackMap locals:
      StackMap stack:
            aload 5 /* nodes */
            iload 10 /* i */
            aconst_null
            aastore
        44: .line 1091
            iinc 10 /* i */ 1
      StackMap locals:
      StackMap stack:
        45: iload 10 /* i */
            iload 6 /* n */
            if_icmplt 37
        end local 10 // int i
        46: .line 1101
            goto 50
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.util.function.Predicate int java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.LinkedBlockingQueue$Node java.util.concurrent.LinkedBlockingQueue$Node[] int int long
      StackMap stack: java.lang.Throwable
        47: astore 12
        48: .line 1102
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        49: .line 1103
            aload 12
            athrow
        50: .line 1102
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        end local 8 // long deathRow
        51: .line 1105
      StackMap locals:
      StackMap stack:
            iload 6 /* n */
            ifle 52
            aload 3 /* p */
            ifnonnull 5
        52: .line 1106
      StackMap locals:
      StackMap stack:
            iload 2 /* removed */
            ireturn
        end local 7 // int len
        end local 6 // int n
        end local 5 // java.util.concurrent.LinkedBlockingQueue$Node[] nodes
        end local 4 // java.util.concurrent.LinkedBlockingQueue$Node ancestor
        end local 3 // java.util.concurrent.LinkedBlockingQueue$Node p
        end local 2 // boolean removed
        end local 1 // java.util.function.Predicate filter
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   53     0      this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   53     1    filter  Ljava/util/function/Predicate<-TE;>;
            1   53     2   removed  Z
            2   53     3         p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            3   53     4  ancestor  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
            4   53     5     nodes  [Ljava/util/concurrent/LinkedBlockingQueue$Node;
           16   21     6         n  I
           24   53     6         n  I
            5   53     7       len  I
            9   14     8         q  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
           26   51     8  deathRow  J
           27   33    10         i  I
           29   31    11         e  TE;
           36   46    10         i  I
           39   43    11         q  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
      Exception table:
        from    to  target  type
           6    21      21  any
          35    47      47  any
    Signature: (Ljava/util/function/Predicate<-TE;>;)Z
    MethodParameters:
        Name  Flags
      filter  

  private void writeObject(java.io.ObjectOutputStream);
    descriptor: (Ljava/io/ObjectOutputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.io.ObjectOutputStream s
         0: .line 1121
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyLock:()V
         1: .line 1124
            aload 1 /* s */
            invokevirtual java.io.ObjectOutputStream.defaultWriteObject:()V
         2: .line 1127
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 2 /* p */
        start local 2 // java.util.concurrent.LinkedBlockingQueue$Node p
         3: goto 6
         4: .line 1128
      StackMap locals: java.util.concurrent.LinkedBlockingQueue$Node
      StackMap stack:
            aload 1 /* s */
            aload 2 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.item:Ljava/lang/Object;
            invokevirtual java.io.ObjectOutputStream.writeObject:(Ljava/lang/Object;)V
         5: .line 1127
            aload 2 /* p */
            getfield java.util.concurrent.LinkedBlockingQueue$Node.next:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            astore 2 /* p */
      StackMap locals:
      StackMap stack:
         6: aload 2 /* p */
            ifnonnull 4
        end local 2 // java.util.concurrent.LinkedBlockingQueue$Node p
         7: .line 1131
            aload 1 /* s */
            aconst_null
            invokevirtual java.io.ObjectOutputStream.writeObject:(Ljava/lang/Object;)V
         8: .line 1132
            goto 12
      StackMap locals: java.util.concurrent.LinkedBlockingQueue java.io.ObjectOutputStream
      StackMap stack: java.lang.Throwable
         9: astore 3
        10: .line 1133
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        11: .line 1134
            aload 3
            athrow
        12: .line 1133
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.fullyUnlock:()V
        13: .line 1135
            return
        end local 1 // java.io.ObjectOutputStream s
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   14     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0   14     1     s  Ljava/io/ObjectOutputStream;
            3    7     2     p  Ljava/util/concurrent/LinkedBlockingQueue$Node<TE;>;
      Exception table:
        from    to  target  type
           1     9       9  any
    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=5, locals=3, args_size=2
        start local 0 // java.util.concurrent.LinkedBlockingQueue this
        start local 1 // java.io.ObjectInputStream s
         0: .line 1147
            aload 1 /* s */
            invokevirtual java.io.ObjectInputStream.defaultReadObject:()V
         1: .line 1149
            aload 0 /* this */
            getfield java.util.concurrent.LinkedBlockingQueue.count:Ljava/util/concurrent/atomic/AtomicInteger;
            iconst_0
            invokevirtual java.util.concurrent.atomic.AtomicInteger.set:(I)V
         2: .line 1150
            aload 0 /* this */
            aload 0 /* this */
            new java.util.concurrent.LinkedBlockingQueue$Node
            dup
            aconst_null
            invokespecial java.util.concurrent.LinkedBlockingQueue$Node.<init>:(Ljava/lang/Object;)V
            dup_x1
            putfield java.util.concurrent.LinkedBlockingQueue.head:Ljava/util/concurrent/LinkedBlockingQueue$Node;
            putfield java.util.concurrent.LinkedBlockingQueue.last:Ljava/util/concurrent/LinkedBlockingQueue$Node;
         3: .line 1155
      StackMap locals:
      StackMap stack:
            aload 1 /* s */
            invokevirtual java.io.ObjectInputStream.readObject:()Ljava/lang/Object;
            astore 2 /* item */
        start local 2 // java.lang.Object item
         4: .line 1156
            aload 2 /* item */
            ifnonnull 6
         5: .line 1157
            goto 8
         6: .line 1158
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 0 /* this */
            aload 2 /* item */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.add:(Ljava/lang/Object;)Z
            pop
        end local 2 // java.lang.Object item
         7: .line 1153
            goto 3
         8: .line 1160
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.io.ObjectInputStream s
        end local 0 // java.util.concurrent.LinkedBlockingQueue this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Ljava/util/concurrent/LinkedBlockingQueue<TE;>;
            0    9     1     s  Ljava/io/ObjectInputStream;
            4    7     2  item  TE;
    Exceptions:
      throws java.io.IOException, java.lang.ClassNotFoundException
    MethodParameters:
      Name  Flags
      s     

  private static boolean lambda$0(java.util.Collection, java.lang.Object);
    descriptor: (Ljava/util/Collection;Ljava/lang/Object;)Z
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
        start local 1 // java.lang.Object e
         0: .line 1030
            aload 0
            aload 1 /* e */
            invokeinterface java.util.Collection.contains:(Ljava/lang/Object;)Z
            ireturn
        end local 1 // java.lang.Object e
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     1     e  TE;

  private static boolean lambda$1(java.util.Collection, java.lang.Object);
    descriptor: (Ljava/util/Collection;Ljava/lang/Object;)Z
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
        start local 1 // java.lang.Object e
         0: .line 1038
            aload 0
            aload 1 /* e */
            invokeinterface java.util.Collection.contains:(Ljava/lang/Object;)Z
            ifeq 1
            iconst_0
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_1
      StackMap locals:
      StackMap stack: int
         2: ireturn
        end local 1 // java.lang.Object e
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     1     e  TE;
}
Signature: <E:Ljava/lang/Object;>Ljava/util/AbstractQueue<TE;>;Ljava/util/concurrent/BlockingQueue<TE;>;Ljava/io/Serializable;
SourceFile: "LinkedBlockingQueue.java"
NestMembers:
  java.util.concurrent.LinkedBlockingQueue$Itr  java.util.concurrent.LinkedBlockingQueue$LBQSpliterator  java.util.concurrent.LinkedBlockingQueue$Node
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  private Itr = java.util.concurrent.LinkedBlockingQueue$Itr of java.util.concurrent.LinkedBlockingQueue
  private final LBQSpliterator = java.util.concurrent.LinkedBlockingQueue$LBQSpliterator of java.util.concurrent.LinkedBlockingQueue
  Node = java.util.concurrent.LinkedBlockingQueue$Node of java.util.concurrent.LinkedBlockingQueue