103.【Java Microbenchmark Harness】(五)

简介: 103.【Java Microbenchmark Harness】

线程 fork(10)

package org.openjdk.jmh.samples;
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.lang.management.ManagementFactory;
import java.util.concurrent.TimeUnit;
/**
 *  我们发现进程pid是一样的,初步推测fork(10),代表新开10个进程
 */
@State(Scope.Thread)
@BenchmarkMode(Mode.AverageTime)
@OutputTimeUnit(TimeUnit.NANOSECONDS)
@Warmup(iterations = 1, time = 1, timeUnit = TimeUnit.SECONDS)  //预热次数和时间
@Measurement(iterations = 1, time = 1, timeUnit = TimeUnit.SECONDS) //测试次数和时间
public class JMHSample_12_Forking {
    @Benchmark
    @Fork(10)  //通过源码我们可以直到,10代表 10 fork
    public int measure_1_c1() {
        return 1;
    }
    @Setup(Level.Trial)  // 在基准执行之前先打印pid。
    public void setup() {
        printProcessID("setup");
    }
    public static void printProcessID(String name) {  //打印pid
        System.out.println();
        System.out.println("--------------");
        System.out.println(name + " pid is : " + ManagementFactory.getRuntimeMXBean().getName());
        System.out.println("--------------");
        System.out.println();
    }
    public static void main(String[] args) throws RunnerException {
        printProcessID("main");  // 执行main方法的时候打印pid
        Options opt = new OptionsBuilder()
                .include(JMHSample_12_Forking.class.getSimpleName())
                .build();
        new Runner(opt).run();  //当他启动的时候,才会开始运行基准
    }
}

fork() 默认值是-1,但效果等于传5

package org.openjdk.jmh.samples;
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.lang.management.ManagementFactory;
import java.util.concurrent.TimeUnit;
/**
 *  我们发现进程pid是一样的,初步推测fork),代表新开5个进程
 */
@State(Scope.Thread)
@BenchmarkMode(Mode.AverageTime)
@OutputTimeUnit(TimeUnit.NANOSECONDS)
@Warmup(iterations = 1, time = 1, timeUnit = TimeUnit.SECONDS)  //预热次数和时间
@Measurement(iterations = 1, time = 1, timeUnit = TimeUnit.SECONDS) //测试次数和时间
public class JMHSample_12_Forking {
    @Benchmark
    @Fork()  //默认是-1 实际传5
    public int measure_1_c1() {
        return 1;
    }
    @Setup(Level.Trial)  // 在基准执行之前先打印pid。
    public void setup() {
        printProcessID("setup");
    }
    public static void printProcessID(String name) {  //打印pid
        System.out.println();
        System.out.println("--------------");
        System.out.println(name + " pid is : " + ManagementFactory.getRuntimeMXBean().getName());
        System.out.println("--------------");
        System.out.println();
    }
    public static void main(String[] args) throws RunnerException {
        printProcessID("main");  // 执行main方法的时候打印pid
        Options opt = new OptionsBuilder()
                .include(JMHSample_12_Forking.class.getSimpleName())
                .build();
        new Runner(opt).run();  //当他启动的时候,才会开始运行基准
    }
}

forking 源码

在同一个JVM中,不同的基准会相互影响的。

package org.openjdk.jmh.samples;
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;
/**
 * 在同一个JVM线程中,我们发现各个基准是相互影响的
 */
@State(Scope.Thread)
@BenchmarkMode(Mode.AverageTime)
@OutputTimeUnit(TimeUnit.NANOSECONDS)
@Warmup(iterations = 1,time = 1,timeUnit = TimeUnit.SECONDS)  //预热次数和时间
@Measurement(iterations = 1,time = 1,timeUnit = TimeUnit.SECONDS) //测试次数和时间
public class JMHSample_12_Forking {
    public interface Counter {  //匿名内部类
        int inc();
    }
    public static class Counter1 implements Counter { //实现接口1
        private int x;
        @Override
        public int inc() {
            return x++;
        }
    }
    public static class Counter2 implements Counter {  //实现接口2
        private int x;
        @Override
        public int inc() {
            return x++;
        }
    }
    public int measure(Counter c) {  //方法
        int s = 0;
        for (int i = 0; i < 10; i++) {
            s += c.inc();
        }
        return s;
    }
    Counter c1 = new Counter1();
    Counter c2 = new Counter2();
    @Benchmark
    @Fork(0)
    public int measure_1_c1() {  //与main方法同进程
        return measure(c1);
    }
    @Benchmark
    @Fork(0)
    public int measure_2_c2() { //与main方法同进程
        return measure(c2);
    }
    @Benchmark
    @Fork(0)
    public int measure_3_c1_again() { //与main方法同进程
        return measure(c1);
    }
    @Benchmark
    @Fork(1)
    public int measure_4_forked_c1() {//与main方法不同进程
        return measure(c1);
    }
    @Benchmark
    @Fork(1)
    public int measure_5_forked_c2() { //与main方法不同进程
        return measure(c2);
    }
    public static void main(String[] args) throws RunnerException {
        Options opt = new OptionsBuilder()
                .include(JMHSample_12_Forking.class.getSimpleName())
                .build();
        new Runner(opt).run();
    }
}

14.什么时候使用fork

大数样本: 大数法则当我们的样本足够多的时候,我们抽取的越多,那么就越接近平均值。 所以我们多开点线程就可以多取样本。

package org.openjdk.jmh.samples;
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;
/**
 *   大数样本: 大数法则当我们的样本足够多的时候,我们抽取的越多,那么就越接近平均值。
 */
@State(Scope.Thread)
@BenchmarkMode(Mode.AverageTime)
@OutputTimeUnit(TimeUnit.MILLISECONDS)
@Warmup(iterations = 1,time = 1,timeUnit = TimeUnit.SECONDS)  //预热次数和时间
@Measurement(iterations = 1,time = 1,timeUnit = TimeUnit.SECONDS) //测试次数和时间
public class JMHSample_13_RunToRun {
    @State(Scope.Thread)
    public static class SleepyState {  //定义一个静态内部类
        public long sleepTime;
        @Setup
        public void setup() {
            sleepTime = (long) (Math.random() * 1000);
            System.out.println("---------------");
            System.out.println("sleepTime-> "+sleepTime);
            System.out.println("---------------");
        }  //生成一个随机休眠数
    }
    /*
     * Now, we will run this different number of times.
     */
    @Benchmark
    @Fork(1)
    public void baseline(SleepyState s) throws InterruptedException {
        TimeUnit.MILLISECONDS.sleep(s.sleepTime);
    }
    @Benchmark
    @Fork(5)
    public void fork_1(SleepyState s) throws InterruptedException {
        TimeUnit.MILLISECONDS.sleep(s.sleepTime);
    }
    @Benchmark
    @Fork(20)
    public void fork_2(SleepyState s) throws InterruptedException {
        TimeUnit.MILLISECONDS.sleep(s.sleepTime);
    }
    public static void main(String[] args) throws RunnerException {
        Options opt = new OptionsBuilder()
                .include(JMHSample_13_RunToRun.class.getSimpleName())
                .warmupIterations(0)
                .measurementIterations(3)
                .build();
        new Runner(opt).run();
    }
}

相关文章
|
JSON 数据可视化 Java
103.【Java Microbenchmark Harness】(六)
103.【Java Microbenchmark Harness】
52 0
103.【Java Microbenchmark Harness】(六)
|
Java
103.【Java Microbenchmark Harness】(三)
103.【Java Microbenchmark Harness】
45 0
103.【Java Microbenchmark Harness】(三)
|
Java
103.【Java Microbenchmark Harness】(二)
103.【Java Microbenchmark Harness】
61 0
103.【Java Microbenchmark Harness】(二)
|
Java 编译器 BI
103.【Java Microbenchmark Harness】(四)
103.【Java Microbenchmark Harness】
72 0
|
Java 测试技术
103.【Java Microbenchmark Harness】(一)
103.【Java Microbenchmark Harness】
66 0
|
Java 测试技术
在java中使用JMH(Java Microbenchmark Harness)做性能测试
在java中使用JMH(Java Microbenchmark Harness)做性能测试
|
6天前
|
安全 Java 调度
Java编程时多线程操作单核服务器可以不加锁吗?
Java编程时多线程操作单核服务器可以不加锁吗?
20 2
|
9天前
|
存储 缓存 Java
java线程内存模型底层实现原理
java线程内存模型底层实现原理
java线程内存模型底层实现原理
|
14天前
|
缓存 Java 应用服务中间件
Java虚拟线程探究与性能解析
本文主要介绍了阿里云在Java-虚拟-线程任务中的新进展和技术细节。
|
11天前
|
Java 开发者
Java中的多线程基础与应用
【9月更文挑战第22天】在Java的世界中,多线程是一块基石,它支撑着现代并发编程的大厦。本文将深入浅出地介绍Java中多线程的基本概念、创建方法以及常见的应用场景,帮助读者理解并掌握这一核心技术。
下一篇
无影云桌面