abstract class java.util.HashMap$HashIterator
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: java.util.HashMap$HashIterator
  super_class: java.lang.Object
{
  java.util.HashMap$Node<K, V> next;
    descriptor: Ljava/util/HashMap$Node;
    flags: (0x0000) 
    Signature: Ljava/util/HashMap$Node<TK;TV;>;

  java.util.HashMap$Node<K, V> current;
    descriptor: Ljava/util/HashMap$Node;
    flags: (0x0000) 
    Signature: Ljava/util/HashMap$Node<TK;TV;>;

  int expectedModCount;
    descriptor: I
    flags: (0x0000) 

  int index;
    descriptor: I
    flags: (0x0000) 

  final java.util.HashMap this$0;
    descriptor: Ljava/util/HashMap;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  void <init>(java.util.HashMap);
    descriptor: (Ljava/util/HashMap;)V
    flags: (0x0000) 
    Code:
      stack=6, locals=3, args_size=2
        start local 0 // java.util.HashMap$HashIterator this
         0: .line 1427
            aload 0 /* this */
            aload 1
            putfield java.util.HashMap$HashIterator.this$0:Ljava/util/HashMap;
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 1428
            aload 0 /* this */
            aload 1
            getfield java.util.HashMap.modCount:I
            putfield java.util.HashMap$HashIterator.expectedModCount:I
         2: .line 1429
            aload 1
            getfield java.util.HashMap.table:[Ljava/util/HashMap$Node;
            astore 2 /* t */
        start local 2 // java.util.HashMap$Node[] t
         3: .line 1430
            aload 0 /* this */
            aload 0 /* this */
            aconst_null
            dup_x1
            putfield java.util.HashMap$HashIterator.next:Ljava/util/HashMap$Node;
            putfield java.util.HashMap$HashIterator.current:Ljava/util/HashMap$Node;
         4: .line 1431
            aload 0 /* this */
            iconst_0
            putfield java.util.HashMap$HashIterator.index:I
         5: .line 1432
            aload 2 /* t */
            ifnull 7
            aload 1
            getfield java.util.HashMap.size:I
            ifle 7
         6: .line 1433
      StackMap locals: java.util.HashMap$HashIterator java.util.HashMap java.util.HashMap$Node[]
      StackMap stack:
            aload 0 /* this */
            getfield java.util.HashMap$HashIterator.index:I
            aload 2 /* t */
            arraylength
            if_icmpge 7
            aload 0 /* this */
            aload 2 /* t */
            aload 0 /* this */
            dup
            getfield java.util.HashMap$HashIterator.index:I
            dup_x1
            iconst_1
            iadd
            putfield java.util.HashMap$HashIterator.index:I
            aaload
            dup_x1
            putfield java.util.HashMap$HashIterator.next:Ljava/util/HashMap$Node;
            ifnull 6
         7: .line 1435
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.util.HashMap$Node[] t
        end local 0 // java.util.HashMap$HashIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Ljava/util/HashMap$HashIterator;
            3    8     2     t  [Ljava/util/HashMap$Node;
    MethodParameters:
        Name  Flags
      this$0  final

  public final boolean hasNext();
    descriptor: ()Z
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.util.HashMap$HashIterator this
         0: .line 1438
            aload 0 /* this */
            getfield java.util.HashMap$HashIterator.next:Ljava/util/HashMap$Node;
            ifnull 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // java.util.HashMap$HashIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljava/util/HashMap$HashIterator;

  final java.util.HashMap$Node<K, V> nextNode();
    descriptor: ()Ljava/util/HashMap$Node;
    flags: (0x0010) ACC_FINAL
    Code:
      stack=6, locals=3, args_size=1
        start local 0 // java.util.HashMap$HashIterator this
         0: .line 1443
            aload 0 /* this */
            getfield java.util.HashMap$HashIterator.next:Ljava/util/HashMap$Node;
            astore 2 /* e */
        start local 2 // java.util.HashMap$Node e
         1: .line 1444
            aload 0 /* this */
            getfield java.util.HashMap$HashIterator.this$0:Ljava/util/HashMap;
            getfield java.util.HashMap.modCount:I
            aload 0 /* this */
            getfield java.util.HashMap$HashIterator.expectedModCount:I
            if_icmpeq 3
         2: .line 1445
            new java.util.ConcurrentModificationException
            dup
            invokespecial java.util.ConcurrentModificationException.<init>:()V
            athrow
         3: .line 1446
      StackMap locals: java.util.HashMap$HashIterator top java.util.HashMap$Node
      StackMap stack:
            aload 2 /* e */
            ifnonnull 5
         4: .line 1447
            new java.util.NoSuchElementException
            dup
            invokespecial java.util.NoSuchElementException.<init>:()V
            athrow
         5: .line 1448
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            aload 2 /* e */
            dup_x1
            putfield java.util.HashMap$HashIterator.current:Ljava/util/HashMap$Node;
            getfield java.util.HashMap$Node.next:Ljava/util/HashMap$Node;
            dup_x1
            putfield java.util.HashMap$HashIterator.next:Ljava/util/HashMap$Node;
            ifnonnull 8
            aload 0 /* this */
            getfield java.util.HashMap$HashIterator.this$0:Ljava/util/HashMap;
            getfield java.util.HashMap.table:[Ljava/util/HashMap$Node;
            dup
            astore 1 /* t */
        start local 1 // java.util.HashMap$Node[] t
         6: ifnull 8
         7: .line 1449
      StackMap locals: java.util.HashMap$HashIterator java.util.HashMap$Node[] java.util.HashMap$Node
      StackMap stack:
            aload 0 /* this */
            getfield java.util.HashMap$HashIterator.index:I
            aload 1 /* t */
            arraylength
            if_icmpge 8
            aload 0 /* this */
            aload 1 /* t */
            aload 0 /* this */
            dup
            getfield java.util.HashMap$HashIterator.index:I
            dup_x1
            iconst_1
            iadd
            putfield java.util.HashMap$HashIterator.index:I
            aaload
            dup_x1
            putfield java.util.HashMap$HashIterator.next:Ljava/util/HashMap$Node;
            ifnull 7
        end local 1 // java.util.HashMap$Node[] t
         8: .line 1451
      StackMap locals: java.util.HashMap$HashIterator top java.util.HashMap$Node
      StackMap stack:
            aload 2 /* e */
            areturn
        end local 2 // java.util.HashMap$Node e
        end local 0 // java.util.HashMap$HashIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Ljava/util/HashMap$HashIterator;
            6    8     1     t  [Ljava/util/HashMap$Node;
            1    9     2     e  Ljava/util/HashMap$Node<TK;TV;>;
    Signature: ()Ljava/util/HashMap$Node<TK;TV;>;

  public final void remove();
    descriptor: ()V
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=6, locals=3, args_size=1
        start local 0 // java.util.HashMap$HashIterator this
         0: .line 1455
            aload 0 /* this */
            getfield java.util.HashMap$HashIterator.current:Ljava/util/HashMap$Node;
            astore 1 /* p */
        start local 1 // java.util.HashMap$Node p
         1: .line 1456
            aload 1 /* p */
            ifnonnull 3
         2: .line 1457
            new java.lang.IllegalStateException
            dup
            invokespecial java.lang.IllegalStateException.<init>:()V
            athrow
         3: .line 1458
      StackMap locals: java.util.HashMap$Node
      StackMap stack:
            aload 0 /* this */
            getfield java.util.HashMap$HashIterator.this$0:Ljava/util/HashMap;
            getfield java.util.HashMap.modCount:I
            aload 0 /* this */
            getfield java.util.HashMap$HashIterator.expectedModCount:I
            if_icmpeq 5
         4: .line 1459
            new java.util.ConcurrentModificationException
            dup
            invokespecial java.util.ConcurrentModificationException.<init>:()V
            athrow
         5: .line 1460
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield java.util.HashMap$HashIterator.current:Ljava/util/HashMap$Node;
         6: .line 1461
            aload 1 /* p */
            getfield java.util.HashMap$Node.key:Ljava/lang/Object;
            astore 2 /* key */
        start local 2 // java.lang.Object key
         7: .line 1462
            aload 0 /* this */
            getfield java.util.HashMap$HashIterator.this$0:Ljava/util/HashMap;
            aload 2 /* key */
            invokestatic java.util.HashMap.hash:(Ljava/lang/Object;)I
            aload 2 /* key */
            aconst_null
            iconst_0
            iconst_0
            invokevirtual java.util.HashMap.removeNode:(ILjava/lang/Object;Ljava/lang/Object;ZZ)Ljava/util/HashMap$Node;
            pop
         8: .line 1463
            aload 0 /* this */
            aload 0 /* this */
            getfield java.util.HashMap$HashIterator.this$0:Ljava/util/HashMap;
            getfield java.util.HashMap.modCount:I
            putfield java.util.HashMap$HashIterator.expectedModCount:I
         9: .line 1464
            return
        end local 2 // java.lang.Object key
        end local 1 // java.util.HashMap$Node p
        end local 0 // java.util.HashMap$HashIterator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Ljava/util/HashMap$HashIterator;
            1   10     1     p  Ljava/util/HashMap$Node<TK;TV;>;
            7   10     2   key  TK;
}
SourceFile: "HashMap.java"
NestHost: java.util.HashMap
InnerClasses:
  abstract HashIterator = java.util.HashMap$HashIterator of java.util.HashMap
  Node = java.util.HashMap$Node of java.util.HashMap