Java 怎么通过openjdk jmh测试long加法

2019年7月29日19:52:53Java 怎么通过openjdk jmh测试long加法已关闭评论 505 1134字阅读3分46秒

1.简介

Java 怎么通过openjdk jmh测试long加法?——请看下文。

2.示例代码

/**
 * 版权所有 编程十万个怎么办(www.tah1986.com)
 */


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.LongAdder;


public class TestLongAdder {
    public static final int[] threadsCountArray = new int[] { 1, 2, 4, 8,
            16, 32, 48, 64 };

    @State(Scope.Benchmark)
    public static class LongAdderWrapper {
        public LongAdder value = new LongAdder();
    }

    @Benchmark
    @BenchmarkMode(Mode.SingleShotTime)
    @OutputTimeUnit(TimeUnit.MILLISECONDS)
    public Long incrementAtomicLoop(final LongAdderWrapper longAdderWrapper) {
        for (int i = 0; i < 1_000_000; i++) {
            longAdderWrapper.value.increment();
        }
        return longAdderWrapper.value.longValue();
    }

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

 
继续阅读
编程十万个怎么办