Path: blob/master/test/micro/org/openjdk/bench/vm/compiler/InterfacePrivateCalls.java
66646 views
/*1* Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*/22package org.openjdk.bench.vm.compiler;2324import org.openjdk.jmh.annotations.Benchmark;25import org.openjdk.jmh.annotations.BenchmarkMode;26import org.openjdk.jmh.annotations.Fork;27import org.openjdk.jmh.annotations.Level;28import org.openjdk.jmh.annotations.Measurement;29import org.openjdk.jmh.annotations.Mode;30import org.openjdk.jmh.annotations.OutputTimeUnit;31import org.openjdk.jmh.annotations.Scope;32import org.openjdk.jmh.annotations.Setup;33import org.openjdk.jmh.annotations.State;3435import java.util.concurrent.TimeUnit;3637@State(Scope.Benchmark)38public class InterfacePrivateCalls {39interface I {40private int bar() { return 0; }41default int foo() {42return bar();43}44}4546static class C1 implements I {}47static class C2 implements I {}48static class C3 implements I {}4950private I[] objs;5152@Setup(Level.Trial)53public void setupTrial() {54objs = new I[3];55objs[0] = new C1();56objs[1] = new C2();57objs[2] = new C3();58}5960@Benchmark61@BenchmarkMode(Mode.AverageTime)62@OutputTimeUnit(TimeUnit.NANOSECONDS)63@Fork(value=1, jvmArgsAppend={"-XX:TieredStopAtLevel=1"})64public void invokePrivateInterfaceMethodC1() {65for (int i = 0; i < objs.length; ++i) {66objs[i].foo();67}68}6970@Benchmark71@BenchmarkMode(Mode.AverageTime)72@OutputTimeUnit(TimeUnit.NANOSECONDS)73@Fork(value=1)74public void invokePrivateInterfaceMethodC2() {75for (int i = 0; i < objs.length; ++i) {76objs[i].foo();77}78}79}808182