Path: blob/master/test/micro/org/openjdk/bench/vm/compiler/ArrayBoundCheckRemoval.java
41161 views
/*1* Copyright (c) 2014, Oracle and/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.Mode;27import org.openjdk.jmh.annotations.OutputTimeUnit;28import org.openjdk.jmh.annotations.Scope;29import org.openjdk.jmh.annotations.Setup;30import org.openjdk.jmh.annotations.State;3132import java.util.concurrent.TimeUnit;3334/**35* Benchmark measuring the gain of removing array bound checks in various cases36*/37@BenchmarkMode(Mode.AverageTime)38@OutputTimeUnit(TimeUnit.NANOSECONDS)39@State(Scope.Thread)40public class ArrayBoundCheckRemoval {4142private int[] a;43private int j, u, v;4445@Setup46public void setup() {47a = new int[200];48}4950@Benchmark51public int[] testForLoopAccess() throws Exception {52int[] a = this.a;53for (int i = 0; i < a.length; i++) {54a[i] = i;55}56return a;57}5859@Benchmark60public int[] testBubblesortStripped() throws Exception {61int[] a = this.a;62int limit = a.length;63int st = -1;6465while (st < limit) {66st++;67limit--;68for (j = st; j < limit; j++) {69u = a[j];70v = a[j + 1];71}72}73return a;74}7576@Benchmark77public int[] testBubblesort() throws Exception {78int[] a = this.a;79int j1;80int limit = a.length;81int st = -1;82while (st < limit) {83boolean flipped = false;84st++;85limit--;86for (j1 = st; j1 < limit; j1++) {87if (a[j1] > a[j1 + 1]) {88int T = a[j1];89a[j1] = a[j1 + 1];90a[j1 + 1] = T;91flipped = true;92}93}94if (!flipped) {95return a;96}97flipped = false;98for (j1 = limit; --j1 >= st; ) {99if (a[j1] > a[j1 + 1]) {100int T = a[j1];101a[j1] = a[j1 + 1];102a[j1 + 1] = T;103flipped = true;104}105}106if (!flipped) {107return a;108}109}110return a;111}112113}114115116