Test Atomic Long openjdk jmh - Java Testing

Java examples for Testing:JDK jmh

Description

Test Atomic Long openjdk jmh

Demo Code



import org.openjdk.jmh.annotations.*;
import org.openjdk.jmh.runner.Runner;
import org.openjdk.jmh.runner.RunnerException;
import org.openjdk.jmh.runner.options.Options;
import org.openjdk.jmh.runner.options.OptionsBuilder;

import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicLong;


public class TestAtomicLong {
    public static final int[] threadsCountArray = new int[] { 1, 2, 4, 8,
            16, 32, 48, 64 };/*from  w w w  . ja va 2 s  .  c  om*/

    @State(Scope.Benchmark)
    public static class AtomicLongWrapper {
        public AtomicLong value = new AtomicLong(0l);
    }

    @Benchmark
    @BenchmarkMode(Mode.SingleShotTime)
    @OutputTimeUnit(TimeUnit.MILLISECONDS)
    public Long incrementAtomicLoop(
            final AtomicLongWrapper atomicLongWrapper) {
        for (int i = 0; i < 1_000_000; i++) {
            atomicLongWrapper.value.incrementAndGet();
        }
        return atomicLongWrapper.value.get();
    }

    public static void main(String[] args) throws RunnerException {
        for (final int threadsCount : threadsCountArray) {
            Options opt = new OptionsBuilder()
                    .include(TestAtomicLong.class.getSimpleName())
                    .jvmArgs("-server", "-Xmx2G").warmupIterations(10)
                    .measurementIterations(25).forks(1)
                    .threads(threadsCount).build();
            new Runner(opt).run();
        }
    }
}

Related Tutorials