abstract class com.mchange.v2.c3p0.test.C3P0BenchmarkApp$Test
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: com.mchange.v2.c3p0.test.C3P0BenchmarkApp$Test
  super_class: java.lang.Object
{
  java.lang.String name;
    descriptor: Ljava/lang/String;
    flags: (0x0000) 

  void <init>(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.mchange.v2.c3p0.test.C3P0BenchmarkApp$Test this
        start local 1 // java.lang.String name
         0: .line 224
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 225
            aload 0 /* this */
            aload 1 /* name */
            putfield com.mchange.v2.c3p0.test.C3P0BenchmarkApp$Test.name:Ljava/lang/String;
            return
        end local 1 // java.lang.String name
        end local 0 // com.mchange.v2.c3p0.test.C3P0BenchmarkApp$Test this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/mchange/v2/c3p0/test/C3P0BenchmarkApp$Test;
            0    2     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  

  public void perform(javax.sql.DataSource, javax.sql.DataSource, int);
    descriptor: (Ljavax/sql/DataSource;Ljavax/sql/DataSource;I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=8, args_size=4
        start local 0 // com.mchange.v2.c3p0.test.C3P0BenchmarkApp$Test this
        start local 1 // javax.sql.DataSource unpooled
        start local 2 // javax.sql.DataSource pooled
        start local 3 // int iterations
         0: .line 229
            aload 0 /* this */
            aload 1 /* unpooled */
            iload 3 /* iterations */
            invokevirtual com.mchange.v2.c3p0.test.C3P0BenchmarkApp$Test.test:(Ljavax/sql/DataSource;I)J
            l2d
            iload 3 /* iterations */
            i2d
            ddiv
            dstore 4 /* msecs_unpooled */
        start local 4 // double msecs_unpooled
         1: .line 230
            aload 0 /* this */
            aload 2 /* pooled */
            iload 3 /* iterations */
            invokevirtual com.mchange.v2.c3p0.test.C3P0BenchmarkApp$Test.test:(Ljavax/sql/DataSource;I)J
            l2d
            iload 3 /* iterations */
            i2d
            ddiv
            dstore 6 /* msecs_pooled */
        start local 6 // double msecs_pooled
         2: .line 231
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield com.mchange.v2.c3p0.test.C3P0BenchmarkApp$Test.name:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " [ "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 3 /* iterations */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " iterations ]:"
            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
         3: .line 232
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "\tunpooled: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            dload 4 /* msecs_unpooled */
            invokevirtual java.lang.StringBuilder.append:(D)Ljava/lang/StringBuilder;
            ldc " msecs"
            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
         4: .line 233
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "\t  pooled: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            dload 6 /* msecs_pooled */
            invokevirtual java.lang.StringBuilder.append:(D)Ljava/lang/StringBuilder;
            ldc " msecs"
            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
         5: .line 234
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "\tspeed-up factor: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            dload 4 /* msecs_unpooled */
            dload 6 /* msecs_pooled */
            ddiv
            invokevirtual java.lang.StringBuilder.append:(D)Ljava/lang/StringBuilder;
            ldc " times"
            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
         6: .line 235
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "\tspeed-up absolute: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            dload 4 /* msecs_unpooled */
            dload 6 /* msecs_pooled */
            dsub
            invokevirtual java.lang.StringBuilder.append:(D)Ljava/lang/StringBuilder;
         7: .line 236
            ldc " msecs"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 235
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         9: .line 237
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual java.io.PrintStream.println:()V
        10: .line 244
            return
        end local 6 // double msecs_pooled
        end local 4 // double msecs_unpooled
        end local 3 // int iterations
        end local 2 // javax.sql.DataSource pooled
        end local 1 // javax.sql.DataSource unpooled
        end local 0 // com.mchange.v2.c3p0.test.C3P0BenchmarkApp$Test this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   11     0            this  Lcom/mchange/v2/c3p0/test/C3P0BenchmarkApp$Test;
            0   11     1        unpooled  Ljavax/sql/DataSource;
            0   11     2          pooled  Ljavax/sql/DataSource;
            0   11     3      iterations  I
            1   11     4  msecs_unpooled  D
            2   11     6    msecs_pooled  D
    Exceptions:
      throws java.lang.Exception
    MethodParameters:
            Name  Flags
      unpooled    
      pooled      
      iterations  

  protected abstract long test(javax.sql.DataSource, int);
    descriptor: (Ljavax/sql/DataSource;I)J
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    Exceptions:
      throws java.lang.Exception
    MethodParameters:
      Name  Flags
      ds    
      n     
}
SourceFile: "C3P0BenchmarkApp.java"
NestHost: com.mchange.v2.c3p0.test.C3P0BenchmarkApp
InnerClasses:
  abstract Test = com.mchange.v2.c3p0.test.C3P0BenchmarkApp$Test of com.mchange.v2.c3p0.test.C3P0BenchmarkApp