public abstract class test.BasePerfTest
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: test.BasePerfTest
  super_class: java.lang.Object
{
  static final int DEFAULT_SECS;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 15

  protected void <init>();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // test.BasePerfTest this
         0: .line 9
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // test.BasePerfTest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ltest/BasePerfTest;

  protected final int test(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)I
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // test.BasePerfTest this
        start local 1 // java.lang.String[] args
         0: .line 14
            aload 1 /* args */
            arraylength
            iconst_1
            if_icmpeq 3
         1: .line 15
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Usage: java ... "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " [file]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 16
            iconst_1
            invokestatic java.lang.System.exit:(I)V
         3: .line 19
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new java.io.File
            dup
            aload 1 /* args */
            iconst_0
            aaload
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            bipush 15
            invokevirtual test.BasePerfTest.test2:(Ljava/io/File;I)I
            istore 2 /* total */
        start local 2 // int total
         4: .line 20
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual java.io.PrintStream.println:()V
         5: .line 21
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Total: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 2 /* total */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         6: .line 22
            iload 2 /* total */
         7: ireturn
        end local 2 // int total
         8: .line 23
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 2 /* t */
        start local 2 // java.lang.Exception t
         9: .line 24
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Error: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* t */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        10: .line 25
            aload 2 /* t */
            invokevirtual java.lang.Exception.printStackTrace:()V
        11: .line 26
            aload 2 /* t */
            athrow
        end local 2 // java.lang.Exception t
        end local 1 // java.lang.String[] args
        end local 0 // test.BasePerfTest this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   12     0   this  Ltest/BasePerfTest;
            0   12     1   args  [Ljava/lang/String;
            4    8     2  total  I
            9   12     2      t  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           3     7       8  Class java.lang.Exception
    Exceptions:
      throws java.lang.Exception
    MethodParameters:
      Name  Flags
      args  

  protected final int test2(java.io.File, int);
    descriptor: (Ljava/io/File;I)I
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Code:
      stack=4, locals=13, args_size=3
        start local 0 // test.BasePerfTest this
        start local 1 // java.io.File file
        start local 2 // int SECS
         0: .line 36
            ldc 100
            invokestatic java.lang.Thread.sleep:(J)V
         1: goto 3
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
         2: pop
         3: .line 37
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.gc:()V
         4: .line 38
            ldc 100
            invokestatic java.lang.Thread.sleep:(J)V
         5: goto 7
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
         6: pop
         7: .line 39
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.gc:()V
         8: .line 40
            ldc 100
            invokestatic java.lang.Thread.sleep:(J)V
         9: goto 11
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
        10: pop
        11: .line 42
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Ok, warmup done. Now doing real testing, running for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 2 /* SECS */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " seconds."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        12: .line 44
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 3 /* nextTime */
        start local 3 // long nextTime
        13: .line 45
            lload 3 /* nextTime */
            iload 2 /* SECS */
            sipush 1000
            imul
            i2l
            ladd
            lstore 5 /* endTime */
        start local 5 // long endTime
        14: .line 46
            iconst_0
            istore 7 /* count */
        start local 7 // int count
        15: .line 47
            iconst_0
            istore 8 /* total */
        start local 8 // int total
        16: .line 48
            iconst_0
            istore 9 /* subtotal */
        start local 9 // int subtotal
        17: .line 50
            lload 3 /* nextTime */
            ldc 1000
            ladd
            lstore 3 /* nextTime */
        18: .line 57
      StackMap locals: test.BasePerfTest java.io.File int long long int int int
      StackMap stack:
            iload 8 /* total */
            aload 0 /* this */
            aload 1 /* file */
            invokevirtual test.BasePerfTest.testExec:(Ljava/io/File;)I
            iadd
            istore 8 /* total */
        19: .line 58
            iload 8 /* total */
            aload 0 /* this */
            aload 1 /* file */
            invokevirtual test.BasePerfTest.testExec:(Ljava/io/File;)I
            iadd
            istore 8 /* total */
        20: .line 59
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 10 /* now */
        start local 10 // long now
        21: .line 60
            lload 10 /* now */
            lload 5 /* endTime */
            lcmp
            ifle 23
        22: .line 61
            goto 40
        23: .line 66
      StackMap locals: long
      StackMap stack:
            iinc 9 /* subtotal */ 2
        24: .line 67
            lload 10 /* now */
            lload 3 /* nextTime */
            lcmp
            ifle 18
        25: .line 68
            iload 7 /* count */
            iload 9 /* subtotal */
            iadd
            istore 7 /* count */
        26: .line 72
            iload 9 /* subtotal */
            iconst_1
            ishr
            iconst_1
            isub
            istore 9 /* subtotal */
        27: .line 75
            iload 9 /* subtotal */
            bipush 35
            if_icmple 30
        28: .line 76
            bipush 43
            istore 12 /* c */
        start local 12 // char c
        29: .line 77
            goto 34
        end local 12 // char c
      StackMap locals:
      StackMap stack:
        30: iload 9 /* subtotal */
            bipush 9
            if_icmple 33
        31: .line 78
            bipush 97
            iload 9 /* subtotal */
            bipush 10
            isub
            iadd
            i2c
            istore 12 /* c */
        start local 12 // char c
        32: .line 79
            goto 34
        end local 12 // char c
        33: .line 80
      StackMap locals:
      StackMap stack:
            bipush 48
            iload 9 /* subtotal */
            iadd
            i2c
            istore 12 /* c */
        start local 12 // char c
        34: .line 82
      StackMap locals: int
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            iload 12 /* c */
            invokevirtual java.io.PrintStream.print:(C)V
        35: .line 83
            lload 3 /* nextTime */
            ldc 1000
            ladd
            lstore 3 /* nextTime */
        36: .line 84
            lload 3 /* nextTime */
            lload 10 /* now */
            lcmp
            ifge 38
        37: .line 85
            lload 10 /* now */
            lstore 3 /* nextTime */
        38: .line 87
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 9 /* subtotal */
        end local 12 // char c
        end local 10 // long now
        39: .line 56
            goto 18
        40: .line 91
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Total iterations done: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 7 /* count */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " [done "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 8 /* total */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        41: .line 92
            iload 8 /* total */
            ireturn
        end local 9 // int subtotal
        end local 8 // int total
        end local 7 // int count
        end local 5 // long endTime
        end local 3 // long nextTime
        end local 2 // int SECS
        end local 1 // java.io.File file
        end local 0 // test.BasePerfTest this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   42     0      this  Ltest/BasePerfTest;
            0   42     1      file  Ljava/io/File;
            0   42     2      SECS  I
           13   42     3  nextTime  J
           14   42     5   endTime  J
           15   42     7     count  I
           16   42     8     total  I
           17   42     9  subtotal  I
           21   39    10       now  J
           29   30    12         c  C
           32   33    12         c  C
           34   39    12         c  C
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.InterruptedException
           4     5       6  Class java.lang.InterruptedException
           8     9      10  Class java.lang.InterruptedException
    Exceptions:
      throws java.lang.Exception
    MethodParameters:
      Name  Flags
      file  
      SECS  

  protected abstract int testExec(java.io.File);
    descriptor: (Ljava/io/File;)I
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    Exceptions:
      throws java.lang.Exception
    MethodParameters:
      Name  Flags
      file  
}
SourceFile: "BasePerfTest.java"