JIT编译性能测试

Wesley13
• 阅读 916

1、JIT编译器相关VM参数

-server 服务端模式
-Xint 解释器执行
-Xcomp 编译器执行
-Xmixed 混合模式
-XX:+TieredCompilation 打开多级编译策略(JDK1.8是默认开启的,如果关闭则 -XX:-TieredCompilation)
-XX:CompileThreshold 编译阈值 -client模式下为1500,-server模式下为10000
-XX:+PrintCompilation 开启编译日志打印

–XX:ReservedCodeCacheSize 代码缓存大小 (64-bit server with Tiered Compilation, Java 8 ,默认是240mb)

2、性能测试

/** * @author: guanjian * @date: 2020/11/06 9:52 * @description: JIT编译测试 */
public class JITTest {
   
 
    /** * 模拟耗时方法 */
    public static double cal() {
   
        double d1 = 0.618d;
        double d2 = 6.18d;
        double d3 = 0d;
 
        for (int i = 0; i < 100000; i++) {
   
            d3 += (d1 * d2) / (d1 * d2);
        }
        return d3;
    }
 
    public static void main(String[] args) {
   
 
        long start = System.currentTimeMillis();
        System.out.format("start : %s \n", start);
 
        for (int i = 0; i < 100000; i++) {
   
            cal();
        }
 
        long end = System.currentTimeMillis();
        System.out.format("end : %s \n", end);
        System.out.format("cost : %s\n", end - start);
    }
}
  • 测试-Xint解释器执行 vs -Xcomp编译器执行性能

50000次,-XX:CompileThreshold为10000触发即时编译,-XX:+TieredCompilation JDK8默认开启分层编译

-server -Xint cost:38077ms
-server -Xcomp cost:4311ms

结论:-Xcomp编译执行更快

50000次,-XX:CompileThreshold为10000触发即时编译,-XX:-TieredCompilation 关闭了分层编译,直接编译

-server -Xint cost:41613ms
-server -Xcomp cost:1587ms

结论:没有了分层编译的加持效果更明显,-Xcomp编译要远远超过-Xint解释器执行

  • 测试-XX:CompileThreshold的影响

100000次,-XX:+TieredCompilation JDK8默认开启分层编译

-server -Xcomp -XX:CompileThreshold=10 cost:7017

-server -Xcomp -XX:CompileThreshold=100000 cost:7686

结论:越早触发优化越能提升性能,由于编译过程也有性能损耗,所以阈值要合理,不然适得其反

  • 测试开启与关闭分层编译性能

50000次,-XX:+TieredCompilation JDK8默认开启分层编译
-server -Xcomp -XX:CompileThreshold=100 -XX:-TieredCompilation cost : 1568ms
-server -Xcomp -XX:CompileThreshold=100 -XX:+TieredCompilation cost : 4281ms

结论:关闭分层编译后,减少了探测优化升级过程,直接编译优化,性能有提升

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Wesley13 Wesley13
3年前
Java8默认情况下是混合执行模式
  即解释型执行(JVM将class转换为底层机器码)和编译型执行(JIT,直接将源码转化为底层机器码),我们可以通过java的启动命令参数来选择的  _List1_ mixedmode即混合模式C:\Users\dmjjavaversionjavaversion"1.8.0_201"Java(TM
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Stella981 Stella981
3年前
JVM中即时编译器JIT与解释器并存
一.学习目标1.了解解释器与编译器的概念与作用。2.知道jvm中三种执行模式。3.了解热点代码。二.解释器模式与编译器模式以及混合模式  字节码文件通过类装载器装载,被分配被分配到JVM的运行时数据区,然后会被执行引擎执行。执行引擎以指令为单位读取Java字节码。它就像一个CPU一样,一条一条地执行机器指令。每个字节码指令
Wesley13 Wesley13
3年前
JVM垃圾回收器
1,先贴上4中回收器的参数:\XX:UseSerialGC串行垃圾回收器\XX:UseParallelGC并行垃圾回收器\XX:UseConcMarkSweepGC并发标记扫描垃圾回收器\XX:UseG1GCG1垃圾回收器2,分别测试每种参数1默认的情况是(XX:UseSerialGC),即使不
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这