public class java.util.LinkedList<E> extends java.util.AbstractSequentialList<E> implements java.util.List<E>, java.util.Deque<E>, java.lang.Cloneable, java.io.Serializable
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: java.util.LinkedList
super_class: java.util.AbstractSequentialList
{
transient int size;
descriptor: I
flags: (0x0080) ACC_TRANSIENT
transient java.util.LinkedList$Node<E> first;
descriptor: Ljava/util/LinkedList$Node;
flags: (0x0080) ACC_TRANSIENT
Signature: Ljava/util/LinkedList$Node<TE;>;
transient java.util.LinkedList$Node<E> last;
descriptor: Ljava/util/LinkedList$Node;
flags: (0x0080) ACC_TRANSIENT
Signature: Ljava/util/LinkedList$Node<TE;>;
private static final long serialVersionUID;
descriptor: J
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 876323262645176354
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.util.AbstractSequentialList.<init>:()V
1: aload 0
iconst_0
putfield java.util.LinkedList.size:I
2: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Ljava/util/LinkedList<TE;>;
public void <init>(java.util.Collection<? extends E>);
descriptor: (Ljava/util/Collection;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.util.LinkedList.<init>:()V
1: aload 0
aload 1
invokevirtual java.util.LinkedList.addAll:(Ljava/util/Collection;)Z
pop
2: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Ljava/util/LinkedList<TE;>;
0 3 1 c Ljava/util/Collection<+TE;>;
Signature: (Ljava/util/Collection<+TE;>;)V
MethodParameters:
Name Flags
c
private void linkFirst();
descriptor: (Ljava/lang/Object;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=4, args_size=2
start local 0 start local 1 0: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 2
start local 2 1: new java.util.LinkedList$Node
dup
aconst_null
aload 1
aload 2
invokespecial java.util.LinkedList$Node.<init>:(Ljava/util/LinkedList$Node;Ljava/lang/Object;Ljava/util/LinkedList$Node;)V
astore 3
start local 3 2: aload 0
aload 3
putfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
3: aload 2
ifnonnull 5
4: aload 0
aload 3
putfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
goto 6
5: StackMap locals: java.util.LinkedList$Node java.util.LinkedList$Node
StackMap stack:
aload 2
aload 3
putfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
6: StackMap locals:
StackMap stack:
aload 0
dup
getfield java.util.LinkedList.size:I
iconst_1
iadd
putfield java.util.LinkedList.size:I
7: aload 0
dup
getfield java.util.LinkedList.modCount:I
iconst_1
iadd
putfield java.util.LinkedList.modCount:I
8: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Ljava/util/LinkedList<TE;>;
0 9 1 e TE;
1 9 2 f Ljava/util/LinkedList$Node<TE;>;
2 9 3 newNode Ljava/util/LinkedList$Node<TE;>;
Signature: (TE;)V
MethodParameters:
Name Flags
e
void linkLast();
descriptor: (Ljava/lang/Object;)V
flags: (0x0000)
Code:
stack=5, locals=4, args_size=2
start local 0 start local 1 0: aload 0
getfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
astore 2
start local 2 1: new java.util.LinkedList$Node
dup
aload 2
aload 1
aconst_null
invokespecial java.util.LinkedList$Node.<init>:(Ljava/util/LinkedList$Node;Ljava/lang/Object;Ljava/util/LinkedList$Node;)V
astore 3
start local 3 2: aload 0
aload 3
putfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
3: aload 2
ifnonnull 5
4: aload 0
aload 3
putfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
goto 6
5: StackMap locals: java.util.LinkedList$Node java.util.LinkedList$Node
StackMap stack:
aload 2
aload 3
putfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
6: StackMap locals:
StackMap stack:
aload 0
dup
getfield java.util.LinkedList.size:I
iconst_1
iadd
putfield java.util.LinkedList.size:I
7: aload 0
dup
getfield java.util.LinkedList.modCount:I
iconst_1
iadd
putfield java.util.LinkedList.modCount:I
8: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Ljava/util/LinkedList<TE;>;
0 9 1 e TE;
1 9 2 l Ljava/util/LinkedList$Node<TE;>;
2 9 3 newNode Ljava/util/LinkedList$Node<TE;>;
Signature: (TE;)V
MethodParameters:
Name Flags
e
void linkBefore(E, java.util.LinkedList$Node<E>);
descriptor: (Ljava/lang/Object;Ljava/util/LinkedList$Node;)V
flags: (0x0000)
Code:
stack=5, locals=5, args_size=3
start local 0 start local 1 start local 2 0: aload 2
getfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
astore 3
start local 3 1: new java.util.LinkedList$Node
dup
aload 3
aload 1
aload 2
invokespecial java.util.LinkedList$Node.<init>:(Ljava/util/LinkedList$Node;Ljava/lang/Object;Ljava/util/LinkedList$Node;)V
astore 4
start local 4 2: aload 2
aload 4
putfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
3: aload 3
ifnonnull 5
4: aload 0
aload 4
putfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
goto 6
5: StackMap locals: java.util.LinkedList$Node java.util.LinkedList$Node
StackMap stack:
aload 3
aload 4
putfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
6: StackMap locals:
StackMap stack:
aload 0
dup
getfield java.util.LinkedList.size:I
iconst_1
iadd
putfield java.util.LinkedList.size:I
7: aload 0
dup
getfield java.util.LinkedList.modCount:I
iconst_1
iadd
putfield java.util.LinkedList.modCount:I
8: return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Ljava/util/LinkedList<TE;>;
0 9 1 e TE;
0 9 2 succ Ljava/util/LinkedList$Node<TE;>;
1 9 3 pred Ljava/util/LinkedList$Node<TE;>;
2 9 4 newNode Ljava/util/LinkedList$Node<TE;>;
Signature: (TE;Ljava/util/LinkedList$Node<TE;>;)V
MethodParameters:
Name Flags
e
succ
private E unlinkFirst(java.util.LinkedList$Node<E>);
descriptor: (Ljava/util/LinkedList$Node;)Ljava/lang/Object;
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=4, args_size=2
start local 0 start local 1 0: aload 1
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
astore 2
start local 2 1: aload 1
getfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
astore 3
start local 3 2: aload 1
aconst_null
putfield java.util.LinkedList$Node.item:Ljava/lang/Object;
3: aload 1
aconst_null
putfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
4: aload 0
aload 3
putfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
5: aload 3
ifnonnull 7
6: aload 0
aconst_null
putfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
goto 8
7: StackMap locals: java.lang.Object java.util.LinkedList$Node
StackMap stack:
aload 3
aconst_null
putfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
8: StackMap locals:
StackMap stack:
aload 0
dup
getfield java.util.LinkedList.size:I
iconst_1
isub
putfield java.util.LinkedList.size:I
9: aload 0
dup
getfield java.util.LinkedList.modCount:I
iconst_1
iadd
putfield java.util.LinkedList.modCount:I
10: aload 2
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Ljava/util/LinkedList<TE;>;
0 11 1 f Ljava/util/LinkedList$Node<TE;>;
1 11 2 element TE;
2 11 3 next Ljava/util/LinkedList$Node<TE;>;
Signature: (Ljava/util/LinkedList$Node<TE;>;)TE;
MethodParameters:
Name Flags
f
private E unlinkLast(java.util.LinkedList$Node<E>);
descriptor: (Ljava/util/LinkedList$Node;)Ljava/lang/Object;
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=4, args_size=2
start local 0 start local 1 0: aload 1
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
astore 2
start local 2 1: aload 1
getfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
astore 3
start local 3 2: aload 1
aconst_null
putfield java.util.LinkedList$Node.item:Ljava/lang/Object;
3: aload 1
aconst_null
putfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
4: aload 0
aload 3
putfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
5: aload 3
ifnonnull 7
6: aload 0
aconst_null
putfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
goto 8
7: StackMap locals: java.lang.Object java.util.LinkedList$Node
StackMap stack:
aload 3
aconst_null
putfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
8: StackMap locals:
StackMap stack:
aload 0
dup
getfield java.util.LinkedList.size:I
iconst_1
isub
putfield java.util.LinkedList.size:I
9: aload 0
dup
getfield java.util.LinkedList.modCount:I
iconst_1
iadd
putfield java.util.LinkedList.modCount:I
10: aload 2
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Ljava/util/LinkedList<TE;>;
0 11 1 l Ljava/util/LinkedList$Node<TE;>;
1 11 2 element TE;
2 11 3 prev Ljava/util/LinkedList$Node<TE;>;
Signature: (Ljava/util/LinkedList$Node<TE;>;)TE;
MethodParameters:
Name Flags
l
E unlink(java.util.LinkedList$Node<E>);
descriptor: (Ljava/util/LinkedList$Node;)Ljava/lang/Object;
flags: (0x0000)
Code:
stack=3, locals=5, args_size=2
start local 0 start local 1 0: aload 1
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
astore 2
start local 2 1: aload 1
getfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
astore 3
start local 3 2: aload 1
getfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
astore 4
start local 4 3: aload 4
ifnonnull 6
4: aload 0
aload 3
putfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
5: goto 8
6: StackMap locals: java.lang.Object java.util.LinkedList$Node java.util.LinkedList$Node
StackMap stack:
aload 4
aload 3
putfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
7: aload 1
aconst_null
putfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
8: StackMap locals:
StackMap stack:
aload 3
ifnonnull 11
9: aload 0
aload 4
putfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
10: goto 13
11: StackMap locals:
StackMap stack:
aload 3
aload 4
putfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
12: aload 1
aconst_null
putfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
13: StackMap locals:
StackMap stack:
aload 1
aconst_null
putfield java.util.LinkedList$Node.item:Ljava/lang/Object;
14: aload 0
dup
getfield java.util.LinkedList.size:I
iconst_1
isub
putfield java.util.LinkedList.size:I
15: aload 0
dup
getfield java.util.LinkedList.modCount:I
iconst_1
iadd
putfield java.util.LinkedList.modCount:I
16: aload 2
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 17 0 this Ljava/util/LinkedList<TE;>;
0 17 1 x Ljava/util/LinkedList$Node<TE;>;
1 17 2 element TE;
2 17 3 next Ljava/util/LinkedList$Node<TE;>;
3 17 4 prev Ljava/util/LinkedList$Node<TE;>;
Signature: (Ljava/util/LinkedList$Node<TE;>;)TE;
MethodParameters:
Name Flags
x
public E getFirst();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 1
start local 1 1: aload 1
ifnonnull 3
2: new java.util.NoSuchElementException
dup
invokespecial java.util.NoSuchElementException.<init>:()V
athrow
3: StackMap locals: java.util.LinkedList$Node
StackMap stack:
aload 1
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/LinkedList<TE;>;
1 4 1 f Ljava/util/LinkedList$Node<TE;>;
Signature: ()TE;
public E getLast();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
astore 1
start local 1 1: aload 1
ifnonnull 3
2: new java.util.NoSuchElementException
dup
invokespecial java.util.NoSuchElementException.<init>:()V
athrow
3: StackMap locals: java.util.LinkedList$Node
StackMap stack:
aload 1
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/LinkedList<TE;>;
1 4 1 l Ljava/util/LinkedList$Node<TE;>;
Signature: ()TE;
public E removeFirst();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 1
start local 1 1: aload 1
ifnonnull 3
2: new java.util.NoSuchElementException
dup
invokespecial java.util.NoSuchElementException.<init>:()V
athrow
3: StackMap locals: java.util.LinkedList$Node
StackMap stack:
aload 0
aload 1
invokevirtual java.util.LinkedList.unlinkFirst:(Ljava/util/LinkedList$Node;)Ljava/lang/Object;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/LinkedList<TE;>;
1 4 1 f Ljava/util/LinkedList$Node<TE;>;
Signature: ()TE;
public E removeLast();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
astore 1
start local 1 1: aload 1
ifnonnull 3
2: new java.util.NoSuchElementException
dup
invokespecial java.util.NoSuchElementException.<init>:()V
athrow
3: StackMap locals: java.util.LinkedList$Node
StackMap stack:
aload 0
aload 1
invokevirtual java.util.LinkedList.unlinkLast:(Ljava/util/LinkedList$Node;)Ljava/lang/Object;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/LinkedList<TE;>;
1 4 1 l Ljava/util/LinkedList$Node<TE;>;
Signature: ()TE;
public void addFirst();
descriptor: (Ljava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual java.util.LinkedList.linkFirst:(Ljava/lang/Object;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/LinkedList<TE;>;
0 2 1 e TE;
Signature: (TE;)V
MethodParameters:
Name Flags
e
public void addLast();
descriptor: (Ljava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual java.util.LinkedList.linkLast:(Ljava/lang/Object;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/LinkedList<TE;>;
0 2 1 e TE;
Signature: (TE;)V
MethodParameters:
Name Flags
e
public boolean contains(java.lang.Object);
descriptor: (Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual java.util.LinkedList.indexOf:(Ljava/lang/Object;)I
iflt 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/LinkedList<TE;>;
0 2 1 o Ljava/lang/Object;
MethodParameters:
Name Flags
o
public int size();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.size:I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/LinkedList<TE;>;
public boolean add();
descriptor: (Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual java.util.LinkedList.linkLast:(Ljava/lang/Object;)V
1: iconst_1
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/LinkedList<TE;>;
0 2 1 e TE;
Signature: (TE;)Z
MethodParameters:
Name Flags
e
public boolean remove(java.lang.Object);
descriptor: (Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 1
ifnonnull 9
1: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 2
start local 2 2: goto 7
3: StackMap locals: java.util.LinkedList$Node
StackMap stack:
aload 2
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
ifnonnull 6
4: aload 0
aload 2
invokevirtual java.util.LinkedList.unlink:(Ljava/util/LinkedList$Node;)Ljava/lang/Object;
pop
5: iconst_1
ireturn
6: StackMap locals:
StackMap stack:
aload 2
getfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
astore 2
StackMap locals:
StackMap stack:
7: aload 2
ifnonnull 3
end local 2 8: goto 16
9: StackMap locals:
StackMap stack:
aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 2
start local 2 10: goto 15
11: StackMap locals: java.util.LinkedList$Node
StackMap stack:
aload 1
aload 2
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ifeq 14
12: aload 0
aload 2
invokevirtual java.util.LinkedList.unlink:(Ljava/util/LinkedList$Node;)Ljava/lang/Object;
pop
13: iconst_1
ireturn
14: StackMap locals:
StackMap stack:
aload 2
getfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
astore 2
StackMap locals:
StackMap stack:
15: aload 2
ifnonnull 11
end local 2 16: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 17 0 this Ljava/util/LinkedList<TE;>;
0 17 1 o Ljava/lang/Object;
2 8 2 x Ljava/util/LinkedList$Node<TE;>;
10 16 2 x Ljava/util/LinkedList$Node<TE;>;
MethodParameters:
Name Flags
o
public boolean addAll(java.util.Collection<? extends E>);
descriptor: (Ljava/util/Collection;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 0
getfield java.util.LinkedList.size:I
aload 1
invokevirtual java.util.LinkedList.addAll:(ILjava/util/Collection;)Z
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/LinkedList<TE;>;
0 1 1 c Ljava/util/Collection<+TE;>;
Signature: (Ljava/util/Collection<+TE;>;)Z
MethodParameters:
Name Flags
c
public boolean addAll(int, java.util.Collection<? extends E>);
descriptor: (ILjava/util/Collection;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=13, args_size=3
start local 0 start local 1 start local 2 0: aload 0
iload 1
invokevirtual java.util.LinkedList.checkPositionIndex:(I)V
1: aload 2
invokeinterface java.util.Collection.toArray:()[Ljava/lang/Object;
astore 3
start local 3 2: aload 3
arraylength
istore 4
start local 4 3: iload 4
ifne 5
4: iconst_0
ireturn
5: StackMap locals: java.lang.Object[] int
StackMap stack:
iload 1
aload 0
getfield java.util.LinkedList.size:I
if_icmpne 9
6: aconst_null
astore 6
start local 6 7: aload 0
getfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
astore 5
start local 5 8: goto 11
end local 6 end local 5 9: StackMap locals:
StackMap stack:
aload 0
iload 1
invokevirtual java.util.LinkedList.node:(I)Ljava/util/LinkedList$Node;
astore 6
start local 6 10: aload 6
getfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
astore 5
start local 5 11: StackMap locals: java.util.LinkedList$Node java.util.LinkedList$Node
StackMap stack:
aload 3
dup
astore 10
arraylength
istore 9
iconst_0
istore 8
goto 20
StackMap locals: java.util.LinkedList int java.util.Collection java.lang.Object[] int java.util.LinkedList$Node java.util.LinkedList$Node top int int java.lang.Object[]
StackMap stack:
12: aload 10
iload 8
aaload
astore 7
start local 7 13: aload 7
astore 11
start local 11 14: new java.util.LinkedList$Node
dup
aload 5
aload 11
aconst_null
invokespecial java.util.LinkedList$Node.<init>:(Ljava/util/LinkedList$Node;Ljava/lang/Object;Ljava/util/LinkedList$Node;)V
astore 12
start local 12 15: aload 5
ifnonnull 17
16: aload 0
aload 12
putfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
goto 18
17: StackMap locals: java.util.LinkedList int java.util.Collection java.lang.Object[] int java.util.LinkedList$Node java.util.LinkedList$Node java.lang.Object int int java.lang.Object[] java.lang.Object java.util.LinkedList$Node
StackMap stack:
aload 5
aload 12
putfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
18: StackMap locals:
StackMap stack:
aload 12
astore 5
end local 12 end local 11 end local 7 19: iinc 8 1
StackMap locals: java.util.LinkedList int java.util.Collection java.lang.Object[] int java.util.LinkedList$Node java.util.LinkedList$Node top int int java.lang.Object[]
StackMap stack:
20: iload 8
iload 9
if_icmplt 12
21: aload 6
ifnonnull 24
22: aload 0
aload 5
putfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
23: goto 26
24: StackMap locals: java.util.LinkedList int java.util.Collection java.lang.Object[] int java.util.LinkedList$Node java.util.LinkedList$Node
StackMap stack:
aload 5
aload 6
putfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
25: aload 6
aload 5
putfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
26: StackMap locals:
StackMap stack:
aload 0
dup
getfield java.util.LinkedList.size:I
iload 4
iadd
putfield java.util.LinkedList.size:I
27: aload 0
dup
getfield java.util.LinkedList.modCount:I
iconst_1
iadd
putfield java.util.LinkedList.modCount:I
28: iconst_1
ireturn
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 29 0 this Ljava/util/LinkedList<TE;>;
0 29 1 index I
0 29 2 c Ljava/util/Collection<+TE;>;
2 29 3 a [Ljava/lang/Object;
3 29 4 numNew I
8 9 5 pred Ljava/util/LinkedList$Node<TE;>;
11 29 5 pred Ljava/util/LinkedList$Node<TE;>;
7 9 6 succ Ljava/util/LinkedList$Node<TE;>;
10 29 6 succ Ljava/util/LinkedList$Node<TE;>;
13 19 7 o Ljava/lang/Object;
14 19 11 e TE;
15 19 12 newNode Ljava/util/LinkedList$Node<TE;>;
Signature: (ILjava/util/Collection<+TE;>;)Z
MethodParameters:
Name Flags
index
c
public void clear();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 1
start local 1 1: goto 7
2: StackMap locals: java.util.LinkedList$Node
StackMap stack:
aload 1
getfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
astore 2
start local 2 3: aload 1
aconst_null
putfield java.util.LinkedList$Node.item:Ljava/lang/Object;
4: aload 1
aconst_null
putfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
5: aload 1
aconst_null
putfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
6: aload 2
astore 1
end local 2 7: StackMap locals:
StackMap stack:
aload 1
ifnonnull 2
end local 1 8: aload 0
aload 0
aconst_null
dup_x1
putfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
putfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
9: aload 0
iconst_0
putfield java.util.LinkedList.size:I
10: aload 0
dup
getfield java.util.LinkedList.modCount:I
iconst_1
iadd
putfield java.util.LinkedList.modCount:I
11: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Ljava/util/LinkedList<TE;>;
1 8 1 x Ljava/util/LinkedList$Node<TE;>;
3 7 2 next Ljava/util/LinkedList$Node<TE;>;
public E get();
descriptor: (I)Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
invokevirtual java.util.LinkedList.checkElementIndex:(I)V
1: aload 0
iload 1
invokevirtual java.util.LinkedList.node:(I)Ljava/util/LinkedList$Node;
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/LinkedList<TE;>;
0 2 1 index I
Signature: (I)TE;
MethodParameters:
Name Flags
index
public E set(int, );
descriptor: (ILjava/lang/Object;)Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=5, args_size=3
start local 0 start local 1 start local 2 0: aload 0
iload 1
invokevirtual java.util.LinkedList.checkElementIndex:(I)V
1: aload 0
iload 1
invokevirtual java.util.LinkedList.node:(I)Ljava/util/LinkedList$Node;
astore 3
start local 3 2: aload 3
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
astore 4
start local 4 3: aload 3
aload 2
putfield java.util.LinkedList$Node.item:Ljava/lang/Object;
4: aload 4
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Ljava/util/LinkedList<TE;>;
0 5 1 index I
0 5 2 element TE;
2 5 3 x Ljava/util/LinkedList$Node<TE;>;
3 5 4 oldVal TE;
Signature: (ITE;)TE;
MethodParameters:
Name Flags
index
element
public void add(int, );
descriptor: (ILjava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
iload 1
invokevirtual java.util.LinkedList.checkPositionIndex:(I)V
1: iload 1
aload 0
getfield java.util.LinkedList.size:I
if_icmpne 3
2: aload 0
aload 2
invokevirtual java.util.LinkedList.linkLast:(Ljava/lang/Object;)V
goto 4
3: StackMap locals:
StackMap stack:
aload 0
aload 2
aload 0
iload 1
invokevirtual java.util.LinkedList.node:(I)Ljava/util/LinkedList$Node;
invokevirtual java.util.LinkedList.linkBefore:(Ljava/lang/Object;Ljava/util/LinkedList$Node;)V
4: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Ljava/util/LinkedList<TE;>;
0 5 1 index I
0 5 2 element TE;
Signature: (ITE;)V
MethodParameters:
Name Flags
index
element
public E remove();
descriptor: (I)Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
invokevirtual java.util.LinkedList.checkElementIndex:(I)V
1: aload 0
aload 0
iload 1
invokevirtual java.util.LinkedList.node:(I)Ljava/util/LinkedList$Node;
invokevirtual java.util.LinkedList.unlink:(Ljava/util/LinkedList$Node;)Ljava/lang/Object;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/LinkedList<TE;>;
0 2 1 index I
Signature: (I)TE;
MethodParameters:
Name Flags
index
private boolean isElementIndex(int);
descriptor: (I)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: iload 1
iflt 1
iload 1
aload 0
getfield java.util.LinkedList.size:I
if_icmpge 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/LinkedList<TE;>;
0 2 1 index I
MethodParameters:
Name Flags
index
private boolean isPositionIndex(int);
descriptor: (I)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: iload 1
iflt 1
iload 1
aload 0
getfield java.util.LinkedList.size:I
if_icmpgt 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/LinkedList<TE;>;
0 2 1 index I
MethodParameters:
Name Flags
index
private java.lang.String outOfBoundsMsg(int);
descriptor: (I)Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: new java.lang.StringBuilder
dup
ldc "Index: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
iload 1
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
ldc ", Size: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
getfield java.util.LinkedList.size:I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/LinkedList<TE;>;
0 1 1 index I
MethodParameters:
Name Flags
index
private void checkElementIndex(int);
descriptor: (I)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
invokevirtual java.util.LinkedList.isElementIndex:(I)Z
ifne 2
1: new java.lang.IndexOutOfBoundsException
dup
aload 0
iload 1
invokevirtual java.util.LinkedList.outOfBoundsMsg:(I)Ljava/lang/String;
invokespecial java.lang.IndexOutOfBoundsException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Ljava/util/LinkedList<TE;>;
0 3 1 index I
MethodParameters:
Name Flags
index
private void checkPositionIndex(int);
descriptor: (I)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
invokevirtual java.util.LinkedList.isPositionIndex:(I)Z
ifne 2
1: new java.lang.IndexOutOfBoundsException
dup
aload 0
iload 1
invokevirtual java.util.LinkedList.outOfBoundsMsg:(I)Ljava/lang/String;
invokespecial java.lang.IndexOutOfBoundsException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Ljava/util/LinkedList<TE;>;
0 3 1 index I
MethodParameters:
Name Flags
index
java.util.LinkedList$Node<E> node(int);
descriptor: (I)Ljava/util/LinkedList$Node;
flags: (0x0000)
Code:
stack=3, locals=4, args_size=2
start local 0 start local 1 0: iload 1
aload 0
getfield java.util.LinkedList.size:I
iconst_1
ishr
if_icmpge 8
1: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 2
start local 2 2: iconst_0
istore 3
start local 3 3: goto 6
4: StackMap locals: java.util.LinkedList$Node int
StackMap stack:
aload 2
getfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
astore 2
5: iinc 3 1
StackMap locals:
StackMap stack:
6: iload 3
iload 1
if_icmplt 4
end local 3 7: aload 2
areturn
end local 2 8: StackMap locals:
StackMap stack:
aload 0
getfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
astore 2
start local 2 9: aload 0
getfield java.util.LinkedList.size:I
iconst_1
isub
istore 3
start local 3 10: goto 13
11: StackMap locals: java.util.LinkedList$Node int
StackMap stack:
aload 2
getfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
astore 2
12: iinc 3 -1
StackMap locals:
StackMap stack:
13: iload 3
iload 1
if_icmpgt 11
end local 3 14: aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Ljava/util/LinkedList<TE;>;
0 15 1 index I
2 8 2 x Ljava/util/LinkedList$Node<TE;>;
3 7 3 i I
9 15 2 x Ljava/util/LinkedList$Node<TE;>;
10 14 3 i I
Signature: (I)Ljava/util/LinkedList$Node<TE;>;
MethodParameters:
Name Flags
index
public int indexOf(java.lang.Object);
descriptor: (Ljava/lang/Object;)I
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=4, args_size=2
start local 0 start local 1 0: iconst_0
istore 2
start local 2 1: aload 1
ifnonnull 10
2: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 3
start local 3 3: goto 8
4: StackMap locals: int java.util.LinkedList$Node
StackMap stack:
aload 3
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
ifnonnull 6
5: iload 2
ireturn
6: StackMap locals:
StackMap stack:
iinc 2 1
7: aload 3
getfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
astore 3
StackMap locals:
StackMap stack:
8: aload 3
ifnonnull 4
end local 3 9: goto 17
10: StackMap locals:
StackMap stack:
aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 3
start local 3 11: goto 16
12: StackMap locals: java.util.LinkedList$Node
StackMap stack:
aload 1
aload 3
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ifeq 14
13: iload 2
ireturn
14: StackMap locals:
StackMap stack:
iinc 2 1
15: aload 3
getfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
astore 3
StackMap locals:
StackMap stack:
16: aload 3
ifnonnull 12
end local 3 17: StackMap locals:
StackMap stack:
iconst_m1
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Ljava/util/LinkedList<TE;>;
0 18 1 o Ljava/lang/Object;
1 18 2 index I
3 9 3 x Ljava/util/LinkedList$Node<TE;>;
11 17 3 x Ljava/util/LinkedList$Node<TE;>;
MethodParameters:
Name Flags
o
public int lastIndexOf(java.lang.Object);
descriptor: (Ljava/lang/Object;)I
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=4, args_size=2
start local 0 start local 1 0: aload 0
getfield java.util.LinkedList.size:I
istore 2
start local 2 1: aload 1
ifnonnull 10
2: aload 0
getfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
astore 3
start local 3 3: goto 8
4: StackMap locals: int java.util.LinkedList$Node
StackMap stack:
iinc 2 -1
5: aload 3
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
ifnonnull 7
6: iload 2
ireturn
7: StackMap locals:
StackMap stack:
aload 3
getfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
astore 3
StackMap locals:
StackMap stack:
8: aload 3
ifnonnull 4
end local 3 9: goto 17
10: StackMap locals:
StackMap stack:
aload 0
getfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
astore 3
start local 3 11: goto 16
12: StackMap locals: java.util.LinkedList$Node
StackMap stack:
iinc 2 -1
13: aload 1
aload 3
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ifeq 15
14: iload 2
ireturn
15: StackMap locals:
StackMap stack:
aload 3
getfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
astore 3
StackMap locals:
StackMap stack:
16: aload 3
ifnonnull 12
end local 3 17: StackMap locals:
StackMap stack:
iconst_m1
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Ljava/util/LinkedList<TE;>;
0 18 1 o Ljava/lang/Object;
1 18 2 index I
3 9 3 x Ljava/util/LinkedList$Node<TE;>;
11 17 3 x Ljava/util/LinkedList$Node<TE;>;
MethodParameters:
Name Flags
o
public E peek();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=2, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 1
start local 1 1: aload 1
ifnonnull 2
aconst_null
goto 3
StackMap locals: java.util.LinkedList$Node
StackMap stack:
2: aload 1
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
StackMap locals:
StackMap stack: java.lang.Object
3: areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/LinkedList<TE;>;
1 4 1 f Ljava/util/LinkedList$Node<TE;>;
Signature: ()TE;
public E element();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual java.util.LinkedList.getFirst:()Ljava/lang/Object;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/LinkedList<TE;>;
Signature: ()TE;
public E poll();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 1
start local 1 1: aload 1
ifnonnull 2
aconst_null
goto 3
StackMap locals: java.util.LinkedList$Node
StackMap stack:
2: aload 0
aload 1
invokevirtual java.util.LinkedList.unlinkFirst:(Ljava/util/LinkedList$Node;)Ljava/lang/Object;
StackMap locals:
StackMap stack: java.lang.Object
3: areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/LinkedList<TE;>;
1 4 1 f Ljava/util/LinkedList$Node<TE;>;
Signature: ()TE;
public E remove();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual java.util.LinkedList.removeFirst:()Ljava/lang/Object;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/LinkedList<TE;>;
Signature: ()TE;
public boolean offer();
descriptor: (Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual java.util.LinkedList.add:(Ljava/lang/Object;)Z
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/LinkedList<TE;>;
0 1 1 e TE;
Signature: (TE;)Z
MethodParameters:
Name Flags
e
public boolean offerFirst();
descriptor: (Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual java.util.LinkedList.addFirst:(Ljava/lang/Object;)V
1: iconst_1
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/LinkedList<TE;>;
0 2 1 e TE;
Signature: (TE;)Z
MethodParameters:
Name Flags
e
public boolean offerLast();
descriptor: (Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual java.util.LinkedList.addLast:(Ljava/lang/Object;)V
1: iconst_1
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/LinkedList<TE;>;
0 2 1 e TE;
Signature: (TE;)Z
MethodParameters:
Name Flags
e
public E peekFirst();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=2, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 1
start local 1 1: aload 1
ifnonnull 2
aconst_null
goto 3
StackMap locals: java.util.LinkedList$Node
StackMap stack:
2: aload 1
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
StackMap locals:
StackMap stack: java.lang.Object
3: areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/LinkedList<TE;>;
1 4 1 f Ljava/util/LinkedList$Node<TE;>;
Signature: ()TE;
public E peekLast();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=2, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
astore 1
start local 1 1: aload 1
ifnonnull 2
aconst_null
goto 3
StackMap locals: java.util.LinkedList$Node
StackMap stack:
2: aload 1
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
StackMap locals:
StackMap stack: java.lang.Object
3: areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/LinkedList<TE;>;
1 4 1 l Ljava/util/LinkedList$Node<TE;>;
Signature: ()TE;
public E pollFirst();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 1
start local 1 1: aload 1
ifnonnull 2
aconst_null
goto 3
StackMap locals: java.util.LinkedList$Node
StackMap stack:
2: aload 0
aload 1
invokevirtual java.util.LinkedList.unlinkFirst:(Ljava/util/LinkedList$Node;)Ljava/lang/Object;
StackMap locals:
StackMap stack: java.lang.Object
3: areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/LinkedList<TE;>;
1 4 1 f Ljava/util/LinkedList$Node<TE;>;
Signature: ()TE;
public E pollLast();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
astore 1
start local 1 1: aload 1
ifnonnull 2
aconst_null
goto 3
StackMap locals: java.util.LinkedList$Node
StackMap stack:
2: aload 0
aload 1
invokevirtual java.util.LinkedList.unlinkLast:(Ljava/util/LinkedList$Node;)Ljava/lang/Object;
StackMap locals:
StackMap stack: java.lang.Object
3: areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/LinkedList<TE;>;
1 4 1 l Ljava/util/LinkedList$Node<TE;>;
Signature: ()TE;
public void push();
descriptor: (Ljava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual java.util.LinkedList.addFirst:(Ljava/lang/Object;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/LinkedList<TE;>;
0 2 1 e TE;
Signature: (TE;)V
MethodParameters:
Name Flags
e
public E pop();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual java.util.LinkedList.removeFirst:()Ljava/lang/Object;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/LinkedList<TE;>;
Signature: ()TE;
public boolean removeFirstOccurrence(java.lang.Object);
descriptor: (Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual java.util.LinkedList.remove:(Ljava/lang/Object;)Z
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/LinkedList<TE;>;
0 1 1 o Ljava/lang/Object;
MethodParameters:
Name Flags
o
public boolean removeLastOccurrence(java.lang.Object);
descriptor: (Ljava/lang/Object;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 1
ifnonnull 9
1: aload 0
getfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
astore 2
start local 2 2: goto 7
3: StackMap locals: java.util.LinkedList$Node
StackMap stack:
aload 2
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
ifnonnull 6
4: aload 0
aload 2
invokevirtual java.util.LinkedList.unlink:(Ljava/util/LinkedList$Node;)Ljava/lang/Object;
pop
5: iconst_1
ireturn
6: StackMap locals:
StackMap stack:
aload 2
getfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
astore 2
StackMap locals:
StackMap stack:
7: aload 2
ifnonnull 3
end local 2 8: goto 16
9: StackMap locals:
StackMap stack:
aload 0
getfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
astore 2
start local 2 10: goto 15
11: StackMap locals: java.util.LinkedList$Node
StackMap stack:
aload 1
aload 2
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
ifeq 14
12: aload 0
aload 2
invokevirtual java.util.LinkedList.unlink:(Ljava/util/LinkedList$Node;)Ljava/lang/Object;
pop
13: iconst_1
ireturn
14: StackMap locals:
StackMap stack:
aload 2
getfield java.util.LinkedList$Node.prev:Ljava/util/LinkedList$Node;
astore 2
StackMap locals:
StackMap stack:
15: aload 2
ifnonnull 11
end local 2 16: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 17 0 this Ljava/util/LinkedList<TE;>;
0 17 1 o Ljava/lang/Object;
2 8 2 x Ljava/util/LinkedList$Node<TE;>;
10 16 2 x Ljava/util/LinkedList$Node<TE;>;
MethodParameters:
Name Flags
o
public java.util.ListIterator<E> listIterator(int);
descriptor: (I)Ljava/util/ListIterator;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
invokevirtual java.util.LinkedList.checkPositionIndex:(I)V
1: new java.util.LinkedList$ListItr
dup
aload 0
iload 1
invokespecial java.util.LinkedList$ListItr.<init>:(Ljava/util/LinkedList;I)V
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Ljava/util/LinkedList<TE;>;
0 2 1 index I
Signature: (I)Ljava/util/ListIterator<TE;>;
MethodParameters:
Name Flags
index
public java.util.Iterator<E> descendingIterator();
descriptor: ()Ljava/util/Iterator;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: new java.util.LinkedList$DescendingIterator
dup
aload 0
invokespecial java.util.LinkedList$DescendingIterator.<init>:(Ljava/util/LinkedList;)V
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/LinkedList<TE;>;
Signature: ()Ljava/util/Iterator<TE;>;
private java.util.LinkedList<E> superClone();
descriptor: ()Ljava/util/LinkedList;
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=2, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.clone:()Ljava/lang/Object;
checkcast java.util.LinkedList
1: areturn
2: StackMap locals:
StackMap stack: java.lang.CloneNotSupportedException
astore 1
start local 1 3: new java.lang.InternalError
dup
aload 1
invokespecial java.lang.InternalError.<init>:(Ljava/lang/Throwable;)V
athrow
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Ljava/util/LinkedList<TE;>;
3 4 1 e Ljava/lang/CloneNotSupportedException;
Exception table:
from to target type
0 1 2 Class java.lang.CloneNotSupportedException
Signature: ()Ljava/util/LinkedList<TE;>;
public java.lang.Object clone();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=1
start local 0 0: aload 0
invokevirtual java.util.LinkedList.superClone:()Ljava/util/LinkedList;
astore 1
start local 1 1: aload 1
aload 1
aconst_null
dup_x1
putfield java.util.LinkedList.last:Ljava/util/LinkedList$Node;
putfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
2: aload 1
iconst_0
putfield java.util.LinkedList.size:I
3: aload 1
iconst_0
putfield java.util.LinkedList.modCount:I
4: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 2
start local 2 5: goto 8
6: StackMap locals: java.util.LinkedList java.util.LinkedList$Node
StackMap stack:
aload 1
aload 2
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
invokevirtual java.util.LinkedList.add:(Ljava/lang/Object;)Z
pop
7: aload 2
getfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
astore 2
StackMap locals:
StackMap stack:
8: aload 2
ifnonnull 6
end local 2 9: aload 1
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Ljava/util/LinkedList<TE;>;
1 10 1 clone Ljava/util/LinkedList<TE;>;
5 9 2 x Ljava/util/LinkedList$Node<TE;>;
public java.lang.Object[] toArray();
descriptor: ()[Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=4, args_size=1
start local 0 0: aload 0
getfield java.util.LinkedList.size:I
anewarray java.lang.Object
astore 1
start local 1 1: iconst_0
istore 2
start local 2 2: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 3
start local 3 3: goto 6
4: StackMap locals: java.lang.Object[] int java.util.LinkedList$Node
StackMap stack:
aload 1
iload 2
iinc 2 1
aload 3
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
aastore
5: aload 3
getfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
astore 3
StackMap locals:
StackMap stack:
6: aload 3
ifnonnull 4
end local 3 7: aload 1
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Ljava/util/LinkedList<TE;>;
1 8 1 result [Ljava/lang/Object;
2 8 2 i I
3 7 3 x Ljava/util/LinkedList$Node<TE;>;
public <T> T[] toArray();
descriptor: ([Ljava/lang/Object;)[Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=5, args_size=2
start local 0 start local 1 0: aload 1
arraylength
aload 0
getfield java.util.LinkedList.size:I
if_icmpge 3
1: aload 1
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
invokevirtual java.lang.Class.getComponentType:()Ljava/lang/Class;
aload 0
getfield java.util.LinkedList.size:I
2: invokestatic java.lang.reflect.Array.newInstance:(Ljava/lang/Class;I)Ljava/lang/Object;
checkcast java.lang.Object[]
astore 1
3: StackMap locals:
StackMap stack:
iconst_0
istore 2
start local 2 4: aload 1
astore 3
start local 3 5: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 4
start local 4 6: goto 9
7: StackMap locals: int java.lang.Object[] java.util.LinkedList$Node
StackMap stack:
aload 3
iload 2
iinc 2 1
aload 4
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
aastore
8: aload 4
getfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
astore 4
StackMap locals:
StackMap stack:
9: aload 4
ifnonnull 7
end local 4 10: aload 1
arraylength
aload 0
getfield java.util.LinkedList.size:I
if_icmple 12
11: aload 1
aload 0
getfield java.util.LinkedList.size:I
aconst_null
aastore
12: StackMap locals:
StackMap stack:
aload 1
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Ljava/util/LinkedList<TE;>;
0 13 1 a [Ljava/lang/Object;
4 13 2 i I
5 13 3 result [Ljava/lang/Object;
6 10 4 x Ljava/util/LinkedList$Node<TE;>;
Signature: <T:Ljava/lang/Object;>([TT;)[TT;
MethodParameters:
Name Flags
a
private void writeObject(java.io.ObjectOutputStream);
descriptor: (Ljava/io/ObjectOutputStream;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual java.io.ObjectOutputStream.defaultWriteObject:()V
1: aload 1
aload 0
getfield java.util.LinkedList.size:I
invokevirtual java.io.ObjectOutputStream.writeInt:(I)V
2: aload 0
getfield java.util.LinkedList.first:Ljava/util/LinkedList$Node;
astore 2
start local 2 3: goto 6
4: StackMap locals: java.util.LinkedList$Node
StackMap stack:
aload 1
aload 2
getfield java.util.LinkedList$Node.item:Ljava/lang/Object;
invokevirtual java.io.ObjectOutputStream.writeObject:(Ljava/lang/Object;)V
5: aload 2
getfield java.util.LinkedList$Node.next:Ljava/util/LinkedList$Node;
astore 2
StackMap locals:
StackMap stack:
6: aload 2
ifnonnull 4
end local 2 7: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Ljava/util/LinkedList<TE;>;
0 8 1 s Ljava/io/ObjectOutputStream;
3 7 2 x Ljava/util/LinkedList$Node<TE;>;
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=2, locals=4, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual java.io.ObjectInputStream.defaultReadObject:()V
1: aload 1
invokevirtual java.io.ObjectInputStream.readInt:()I
istore 2
start local 2 2: iconst_0
istore 3
start local 3 3: goto 6
4: StackMap locals: int int
StackMap stack:
aload 0
aload 1
invokevirtual java.io.ObjectInputStream.readObject:()Ljava/lang/Object;
invokevirtual java.util.LinkedList.linkLast:(Ljava/lang/Object;)V
5: iinc 3 1
StackMap locals:
StackMap stack:
6: iload 3
iload 2
if_icmplt 4
end local 3 7: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Ljava/util/LinkedList<TE;>;
0 8 1 s Ljava/io/ObjectInputStream;
2 8 2 size I
3 7 3 i I
Exceptions:
throws java.io.IOException, java.lang.ClassNotFoundException
MethodParameters:
Name Flags
s
public java.util.Spliterator<E> spliterator();
descriptor: ()Ljava/util/Spliterator;
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=1, args_size=1
start local 0 0: new java.util.LinkedList$LLSpliterator
dup
aload 0
iconst_m1
iconst_0
invokespecial java.util.LinkedList$LLSpliterator.<init>:(Ljava/util/LinkedList;II)V
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/util/LinkedList<TE;>;
Signature: ()Ljava/util/Spliterator<TE;>;
}
Signature: <E:Ljava/lang/Object;>Ljava/util/AbstractSequentialList<TE;>;Ljava/util/List<TE;>;Ljava/util/Deque<TE;>;Ljava/lang/Cloneable;Ljava/io/Serializable;
SourceFile: "LinkedList.java"
NestMembers:
java.util.LinkedList$DescendingIterator java.util.LinkedList$LLSpliterator java.util.LinkedList$ListItr java.util.LinkedList$Node
InnerClasses:
private DescendingIterator = java.util.LinkedList$DescendingIterator of java.util.LinkedList
final LLSpliterator = java.util.LinkedList$LLSpliterator of java.util.LinkedList
private ListItr = java.util.LinkedList$ListItr of java.util.LinkedList
private Node = java.util.LinkedList$Node of java.util.LinkedList