热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JMH基准测试研究

JMHBenchMark叫做基准测试,主要是用来测试一些方法的性能,可以根据不同参数,以不同的单位进行计算。可以通过设置Benchma

JMH

BenchMark 叫做基准测试,主要是用来测试一些方法的性能,可以根据不同参数,以不同的单位进行计算。

可以通过设置BenchmarkMode 参数来设置是使用吞吐量为单位还是平均时间作为单位

Java Benchmark Harness, JMH是专门用于代码微基准测试的工具套件。这里的微,就是可以基于方法层面,精度可以达到毫秒级别。

JMH的 主要应用场景:

1.想准确的知道某个方法需要执行多长时间以及与传参之间的关系

2.对比同一个接口,在不同条件下的吞吐量

3.查看单位时间能执行多少强求

入门实现

首先JMH有一个实现清单示例清单。不得不说英文资料只要想找比中文资料要多得多。我们这里来实现下hello world

添加pom依赖:

org.openjdk.jmhjmh-core1.19

org.openjdk.jmhjmh-generator-annprocess1.19provided

这里需要注意,我第一下是用0.17版本,然后在代码里面添加@Benchmark 注解的时候,一直引不到包。后来发现就是这里的版本问题,写到1.19就没有问题了。

public class HelloWorld {@Benchmarkpublic void hello(){}public static void main(String[] args) throws RunnerException {Options opt = new OptionsBuilder().include(HelloWorld.class.getSimpleName()).forks(1).build();new Runner(opt).run();}
}

执行后的输出结果是:

# JMH version: 1.19
# VM version: JDK 1.8.0_181, VM 25.181-b13
# VM invoker: D:\Program Files\Java\jdk1.8.0_181\jre\bin\java.exe
# VM options: -Dvisualvm.id=610415878661292 -javaagent:D:\Program
Files\JetBrains\IntelliJ IDEA 2018.3\lib\idea_rt.jar=63740:D:\Program
Files\JetBrains\IntelliJ IDEA 2018.3\bin -Dfile.encoding=UTF-8
# Warmup: 20 iterations, 1 s each
# Measurement: 20 iterations, 1 s each
# Timeout: 10 min per iteration
# Threads: 1 thread, will synchronize iterations
# Benchmark mode: Throughput, ops/time
# Benchmark: jmh.HelloWorld.hello# Run progress: 0.00% complete, ETA 00:00:40
# Fork: 1 of 1
# Warmup Iteration 1: 3001357376.599 ops/s
# Warmup Iteration 2: 3224879376.706 ops/s
# Warmup Iteration 3: 3216559672.446 ops/s
# Warmup Iteration 4: 3131575191.942 ops/s
# Warmup Iteration 5: 3149948207.385 ops/s
# Warmup Iteration 6: 2830803401.832 ops/s
# Warmup Iteration 7: 3070451939.640 ops/s

里面具体的Warmup  ,Benchmark mode , threads都是JMH 中的一些特有概念。

基本概念

Mode 

Mode 表示 JMH 进行 Benchmark 时所使用的模式。通常是测量的维度不同,或是测量的方式不同。目前 JMH 共有四种模式:

  1. Throughput: 整体吞吐量,例如“1秒内可以执行多少次调用”。
  2. AverageTime: 调用的平均时间,例如“每次调用平均耗时xxx毫秒”。
  3. SampleTime: 随机取样,最后输出取样结果的分布,例如“99%的调用在xxx毫秒以内,99.99%的调用在xxx毫秒以内”
  4. SingleShotTime: 以上模式都是默认一次 iteration 是 1s,唯有 SingleShotTime 是只运行一次。往往同时把 warmup 次数设为0,用于测试冷启动时的性能。

Interation 

Iteration是JMH进行测试的最小单位。大部分模式下,iteration代表的是一秒,JMH会在这一秒内不断调用需要benchmark的方法,然后根据模式对其采样,计算吞吐量,计算平均执行时间等。

Warmup 

Warmup是指在实际进行Benchmark前先进行预热的行为。因为JVM的JIT机制的存在,如果某个函数被调用多次以后,JVM会尝试将其编译成为机器码从而提高执行速度。所以为了让benchmark的结果更加接近真实情况就需要进行预热。

注解

现在来解释一下上面例子中使用到的注解,其实很多注解的意义完全可以望文生义 :

@Benchmark 
表示该方法是需要进行 benchmark 的对象,用法和 JUnit 的 @Test 类似。

@Mode
Mode 如之前所说,表示 JMH 进行 Benchmark 时所使用的模式。

@State
State 用于声明某个类是一个“状态”,然后接受一个 Scope 参数用来表示该状态的共享范围。因为很多 benchmark 会需要一些表示状态的类,JMH 允许你把这些类以依赖注入的方式注入到 benchmark 函数里。Scope 主要分为两种。

  1. Thread: 该状态为每个线程独享。
  2. Benchmark: 该状态在所有线程间共享。
     

@OutputTimeUnit
benchmark 结果所使用的时间单位。

fork

进行 fork 的次数。如果 fork 数是2的话,则 JMH 会 fork 出两个进程来进行测试。

warmupIterations

预热的迭代次数。

measurementIterations

实际测量的迭代次数。

 


推荐阅读
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 本问题探讨了在特定条件下排列儿童队伍的方法数量。题目要求计算满足条件的队伍排列总数,并使用递推算法和大数处理技术来解决这一问题。 ... [详细]
  • 异常要理解Java异常处理是如何工作的,需要掌握一下三种异常类型:检查性异常:最具代表性的检查性异常是用户错误或问题引起的异常ÿ ... [详细]
  • 本文介绍如何使用 Android 的 Canvas 和 View 组件创建一个简单的绘图板应用程序,支持触摸绘画和保存图片功能。 ... [详细]
  • 本文详细解析了Java中hashCode()和equals()方法的实现原理及其在哈希表结构中的应用,探讨了两者之间的关系及其实现时需要注意的问题。 ... [详细]
  • Struts与Spring框架的集成指南
    本文详细介绍了如何将Struts和Spring两个流行的Java Web开发框架进行整合,涵盖从环境配置到代码实现的具体步骤。 ... [详细]
  • 本文详细介绍如何在Linux系统中配置SSH密钥对,以实现从一台主机到另一台主机的无密码登录。内容涵盖密钥对生成、公钥分发及权限设置等关键步骤。 ... [详细]
  • 本文详细介绍了如何使用 MySQL 查询特定时间段的数据,包括今天、本周、上周、本月和上个月的数据。适合对 MySQL 查询感兴趣的读者。 ... [详细]
  • 本文详细介绍了 org.apache.commons.io.IOCase 类中的 checkCompareTo() 方法,通过多个代码示例展示其在不同场景下的使用方法。 ... [详细]
  • 问题描述:通过添加最少数量的括号,使得给定的括号序列变为合法,并输出最终的合法序列。数据范围:字符串长度不超过100。涉及算法:区间动态规划(Interval DP)。 ... [详细]
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • 本文将探讨Java编程语言中对象和类的核心概念,帮助读者更好地理解和应用面向对象编程的思想。通过实际例子和代码演示,我们将揭示如何在Java中定义、创建和使用对象。 ... [详细]
  • 采用IKE方式建立IPsec安全隧道
    一、【组网和实验环境】按如上的接口ip先作配置,再作ipsec的相关配置,配置文本见文章最后本文实验采用的交换机是H3C模拟器,下载地址如 ... [详细]
  • Java 实现二维极点算法
    本文介绍了一种使用 Java 编程语言实现的二维极点算法。该算法用于从一组二维坐标中筛选出极点,适用于需要处理几何图形和空间数据的应用场景。文章不仅详细解释了算法的工作原理,还提供了完整的代码示例。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
author-avatar
刘国彬2012_380
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有