test/micro/org/openjdk/bench/java/lang/reflect/Proxy/ProxyPerf.java
author rriggs
Wed, 21 Aug 2019 16:19:17 -0400
changeset 57827 425412369353
permissions -rw-r--r--
8207814: (proxy) upgrade the proxy class generator Reviewed-by: mchung
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
57827
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
     1
/*
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
     2
 * Copyright (c) 2014, 2019, Oracle and/or its affiliates. All rights reserved.
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
     4
 *
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
     7
 * published by the Free Software Foundation.
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
     8
 *
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    13
 * accompanied this code).
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    14
 *
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    18
 *
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    21
 * questions.
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    22
 */
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    23
package org.openjdk.bench.java.lang.reflect.proxy;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    24
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    25
import java.util.List;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    26
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    27
import org.openjdk.jmh.annotations.Benchmark;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    28
import org.openjdk.jmh.annotations.BenchmarkMode;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    29
import org.openjdk.jmh.annotations.CompilerControl;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    30
import org.openjdk.jmh.annotations.Fork;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    31
import org.openjdk.jmh.annotations.Measurement;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    32
import org.openjdk.jmh.annotations.Mode;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    33
import org.openjdk.jmh.annotations.OutputTimeUnit;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    34
import org.openjdk.jmh.annotations.Scope;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    35
import org.openjdk.jmh.annotations.Setup;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    36
import org.openjdk.jmh.annotations.State;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    37
import org.openjdk.jmh.annotations.Warmup;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    38
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    39
import org.openjdk.jmh.infra.Blackhole;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    40
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    41
import java.lang.reflect.InvocationHandler;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    42
import java.lang.reflect.InvocationTargetException;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    43
import java.lang.reflect.Method;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    44
import java.lang.reflect.Modifier;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    45
import java.util.concurrent.TimeUnit;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    46
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    47
/**
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    48
 * Benchmark measuring java.lang.reflect.ProxyGenerator.generateProxyClass.
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    49
 * It bypasses the cache of proxies to measure the time to construct a proxy.
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    50
 */
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    51
@Warmup(iterations = 5)
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    52
@Measurement(iterations = 10)
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    53
@Fork(value = 1)
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    54
@BenchmarkMode(Mode.AverageTime)
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    55
@OutputTimeUnit(TimeUnit.NANOSECONDS)
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    56
@State(Scope.Thread)
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    57
public class ProxyPerf {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    58
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    59
    /**
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    60
     * Sample results from a Dell T7610.
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    61
     * Benchmark                        Mode  Cnt      Score      Error  Units
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    62
     *      ProxyPerf.genIntf_1              avgt   10  35325.428 +/-  780.459  ns/op
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    63
     *      ProxyPerf.genIntf_1_V49          avgt   10  34309.423 +/-  727.188  ns/op
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    64
     *      ProxyPerf.genStringsIntf_3       avgt   10  46600.366 +/-  663.812  ns/op
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    65
     *      ProxyPerf.genStringsIntf_3_V49   avgt   10  45911.817 +/- 1598.536  ns/op
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    66
     *      ProxyPerf.genZeroParams          avgt   10  33245.048 +/-  437.988  ns/op
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    67
     *      ProxyPerf.genZeroParams_V49      avgt   10  32954.254 +/- 1041.932  ns/op
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    68
     *      ProxyPerf.getPrimsIntf_2         avgt   10  43987.819 +/-  837.443  ns/op
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    69
     *      ProxyPerf.getPrimsIntf_2_V49     avgt   10  42863.462 +/- 1193.480  ns/op
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    70
     */
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    71
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    72
    public interface Intf_1 {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    73
        public Object mL(Object o);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    74
    }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    75
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    76
    public interface Intf_2 {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    77
        public int m1I(int i);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    78
        public long m2IJ(int i, long l);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    79
    }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    80
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    81
    public interface Intf_3 {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    82
        public void mString(String s1);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    83
        public String m2String(String s1);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    84
        public String m2String(String s1, String s2);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    85
    }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    86
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    87
    private InvocationHandler handler;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    88
    private ClassLoader classloader;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    89
    private Method proxyGen;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    90
    private Method proxyGenV49;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    91
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    92
    @Setup
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    93
    public void setup() {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    94
        try {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    95
            handler = (Object proxy, Method method, Object[] args) -> null;
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    96
            classloader = ClassLoader.getSystemClassLoader();
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    97
            Class<?> proxyGenClass = Class.forName("java.lang.reflect.ProxyGenerator");
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    98
            proxyGen = proxyGenClass.getDeclaredMethod("generateProxyClass",
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
    99
                    ClassLoader.class, String.class, java.util.List.class, int.class);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   100
            proxyGen.setAccessible(true);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   101
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   102
            // Init access to the old Proxy generator
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   103
            Class<?> proxyGenClassV49 = Class.forName("java.lang.reflect.ProxyGenerator_v49");
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   104
            proxyGenV49 = proxyGenClassV49.getDeclaredMethod("generateProxyClass",
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   105
                    String.class, java.util.List.class, int.class);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   106
            proxyGenV49.setAccessible(true);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   107
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   108
        } catch (Exception ex) {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   109
            ex.printStackTrace();
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   110
            throw new RuntimeException("ProxyClass setup fails", ex);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   111
        }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   112
    }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   113
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   114
    @Benchmark
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   115
    public void genZeroParams(Blackhole bh) throws Exception {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   116
        List<Class<?>> interfaces = List.of(Runnable.class);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   117
        bh.consume(proxyGen.invoke(null, classloader, "ProxyImpl", interfaces, 1));
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   118
    }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   119
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   120
    @Benchmark
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   121
    public void genIntf_1(Blackhole bh) throws Exception {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   122
        List<Class<?>> interfaces = List.of(Intf_1.class);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   123
        bh.consume(proxyGen.invoke(null, classloader, "ProxyImpl", interfaces, 1));
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   124
    }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   125
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   126
    @Benchmark
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   127
    public void getPrimsIntf_2(Blackhole bh) throws Exception {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   128
        List<Class<?>> interfaces = List.of(Intf_2.class);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   129
        bh.consume(proxyGen.invoke(null, classloader, "ProxyImpl", interfaces, 1));
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   130
    }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   131
    @Benchmark
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   132
    public void genStringsIntf_3(Blackhole bh) throws Exception {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   133
        List<Class<?>> interfaces = List.of(Intf_3.class);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   134
        bh.consume(proxyGen.invoke(null, classloader, "ProxyImpl", interfaces, 1));
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   135
    }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   136
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   137
    // Generate using the V49inal generator for comparison
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   138
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   139
    @Benchmark
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   140
    public void genZeroParams_V49(Blackhole bh) throws Exception {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   141
        List<Class<?>> interfaces = List.of(Runnable.class);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   142
        bh.consume(proxyGenV49.invoke(null, "ProxyImpl", interfaces, 1));
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   143
    }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   144
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   145
    @Benchmark
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   146
    public void genIntf_1_V49(Blackhole bh) throws Exception {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   147
        List<Class<?>> interfaces = List.of(Intf_1.class);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   148
        bh.consume(proxyGenV49.invoke(null, "ProxyImpl", interfaces, 1));
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   149
    }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   150
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   151
    @Benchmark
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   152
    public void getPrimsIntf_2_V49(Blackhole bh) throws Exception {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   153
        List<Class<?>> interfaces = List.of(Intf_2.class);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   154
        bh.consume(proxyGenV49.invoke(null, "ProxyImpl", interfaces, 1));
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   155
    }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   156
    @Benchmark
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   157
    public void genStringsIntf_3_V49(Blackhole bh) throws Exception {
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   158
        List<Class<?>> interfaces = List.of(Intf_3.class);
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   159
        bh.consume(proxyGenV49.invoke(null, "ProxyImpl", interfaces, 1));
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   160
    }
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   161
425412369353 8207814: (proxy) upgrade the proxy class generator
rriggs
parents:
diff changeset
   162
}