Path: blob/master/test/micro/org/openjdk/bench/java/util/ArraysFill.java
41161 views
/*1* Copyright (c) 2018, 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.java.util;2324import org.openjdk.jmh.annotations.Benchmark;25import org.openjdk.jmh.annotations.BenchmarkMode;26import org.openjdk.jmh.annotations.Measurement;27import org.openjdk.jmh.annotations.Mode;28import org.openjdk.jmh.annotations.OutputTimeUnit;29import org.openjdk.jmh.annotations.Param;30import org.openjdk.jmh.annotations.Scope;31import org.openjdk.jmh.annotations.Setup;32import org.openjdk.jmh.annotations.State;33import org.openjdk.jmh.annotations.Warmup;3435import java.util.Arrays;36import java.util.concurrent.TimeUnit;3738@BenchmarkMode(Mode.AverageTime)39@OutputTimeUnit(TimeUnit.NANOSECONDS)40@State(Scope.Thread)41public class ArraysFill {4243@Param({"10", "266", "2048"})44public int size;4546public byte[] testByteArray;47public char[] testCharArray;48public short[] testShortArray;49public int[] testIntArray;50public long[] testLongArray;51public float[] testFloatArray;52public double[] testDoubleArray;5354@Setup55public void setup() {56testByteArray = new byte[size];57testCharArray = new char[size];58testShortArray = new short[size];59testIntArray = new int[size];60testLongArray = new long[size];61testFloatArray = new float[size];62testDoubleArray = new double[size];6364}6566@Benchmark67@Warmup(iterations = 3)68@Measurement(iterations = 3)69public void testCharFill() {70Arrays.fill(testCharArray, (char) -1);71}7273@Benchmark74@Warmup(iterations = 3)75@Measurement(iterations = 3)76public void testByteFill() {77Arrays.fill(testByteArray, (byte) -1);78}7980@Benchmark81@Warmup(iterations = 3)82@Measurement(iterations = 3)83public void testShortFill() {84Arrays.fill(testShortArray, (short) -1);85}8687@Benchmark88@Warmup(iterations = 3)89@Measurement(iterations = 3)90public void testIntFill() {91Arrays.fill(testIntArray, -1);92}9394@Benchmark95@Warmup(iterations = 3)96@Measurement(iterations = 3)97public void testLongFill() {98Arrays.fill(testLongArray, -1);99}100101@Benchmark102@Warmup(iterations = 3)103@Measurement(iterations = 3)104public void testFloatFill() {105Arrays.fill(testFloatArray, (float) -1.0);106}107108@Benchmark109@Warmup(iterations = 3)110@Measurement(iterations = 3)111public void testDoubleFill() {112Arrays.fill(testDoubleArray, -1.0);113}114}115116117