JIT介绍

news2024/11/24 4:25:45

ec8702142c6d445f86efc899aca150ea.jpgJIT全称:Just in time。中文译为:即时的、实时的。

 

 

JVM中的这项技术名为:实时编译技术,也叫即时编译技术。就是在java程序运行的过程中,将字节码编译为机器码运行在本地,而不是通过JVM解释运行(字节码都是通过JVM解释运行的)。

 

我们先来思考一个问题,java代码是如何“跑起来”的?

 

我们编写好的java代码,通过点一下IDE中的运行按钮,就看到程序运行起来的样子了,那么这一过程发生了什么呢,来看下:

 

第一步:javac工具将.java文件编译成.class文件;

 

第二部:jvm将.class文件(.class文件中的内容都是字节码,字节码由opcode和操作数组成)加载到jvm内存中,并逐行运行其中的指令。这里的运行是解释运行的,需要通过解释器将字节码指令转换成机器码(汇编)并运行。

 

由于解释运行的效率不如直接运行机器码,那么jvm为什么不把字节码指令全部编译成机器码然后运行呢,也就是不需要jvm了,只需要一个把字节码编译成机器码的编译器即可。

 

但是把所有字节码都编译成机器码是很费时的,导致java程序启动很缓慢。

 

所以JIT支持三种情况:混合模式(Mixed Mode),解释模式(Interpreted Mode),编译模式(Compiled Mode)。

 

用户在运行java程序时可以通过参数自行选择,默认是混合模式。

 

解释模式:java -Xint 

 

编译模式:java -Xcomp

 

下面我们正式开始介绍编译部分:

 

Java中内置了两个即时编译器有两个:clientCompiler 和 serverCompiler,简称为C1和C2(也叫Opto编译器)。

 

clientCompiler 更注重编译的效率,追求快速完成编译,对代码进行简单、可靠的编译。优点:编译速度快;缺点:编译质量不如C2,因为只是基于代码的静态编译。C2是动态编译。(关于静态编译和动态编译的对比,可以参考《静态编译&动态编译》)

 

serverCompiler 更注重编译的质量,追求最大限度优化代码运行效率。会根据监控(Profiling)收集上来的信息进行优化。比如:热点代码检测。优点:编译质量高;缺点:编译速度慢。

 

为了达到一个平衡,JDK1.7开始就有了分层编译(Tiered Compilation),根据编译器编译、优化的规模与耗时,划分出不同的编译层次,包括:

 

第0层:程序解释执行,不开启性能监控(Profiling),可触发第1层编译。

 

第1层:也称为C1编译,将字节码编译成机器码,进行简单、可靠的优化,如有必要将加入性能监控的逻辑。

 

第2层(或以上):也称为C2编译,将字节码编译成机器码,但是会启用一些编译耗时较长的优化,甚至会根据性能监控信息进行一些不可靠的激进优化。

 

也可以更加详细的分为:

 

复制代码

第 0 层:程序解释执行,默认开启性能监控功能(Profiling),如果不开启,可触发第二层编译;

 

第 1 层:可称为 C1 编译,将字节码编译为本地代码,进行简单、可靠的优化,不开启 Profiling;

 

第 2 层:也称为 C1 编译,开启 Profiling,仅执行带方法调用次数和循环回边执行次数 profiling 的 C1 编译;

 

第 3 层:也称为 C1 编译,执行所有带 Profiling 的 C1 编译;

 

第 4 层:可称为 C2 编译,也是将字节码编译为本地代码,但是会启用一些编译耗时较长的优化,甚至会根据性能监控信息进行一些不可靠的激进优化。

复制代码

 

 

这里提到了不可靠的优化,是的,不是所有的优化都提升程序的运行效率。有时候优化了还不如不优化,当编译器发现优化后的代码运行效率不如之前,或者出现“罕见陷阱(Uncommon Trap)”时,可以通过逆优化(Deoptimization)退回到优化前的状态继续执行。

 

要退回的那个状态就是“逃生门”,解释运行就是C1的逃生门,C1就是C2的逃生门。

 

Tips:编译动作是异步的,不会阻塞代码运行,如果一个方法在编译中,那么就会解释执行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1051123.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

微信公众号网页授权登录获取用户基本信息

概述 微信公众号网页授权登录后微信获取用户基本信息,部署即可运行完整demo 详细 一、前言 (1)适合人群 1,JAVA服务端开发人员 2,初级人员开发人员 3,了解spring springboot maven 3,了…

结构型设计模式——桥接模式

摘要 桥接模式(Bridge pattern): 使用桥接模式通过将实现和抽象放在两个不同的类层次中而使它们可以独立改变。 一、桥接模式的意图 将抽象与实现分离开来,使它们可以独立变化。 二、桥接模式的类图 Abstraction: 定义抽象类的接口Implementor: 定义实现类接口 …

蓝桥杯 题库 简单 每日十题 day12

01 列名 问题描述 在Excel中,列的名称使用英文字母的组合。前26列用一个字母,依 次为A到Z,接下来2626列使用两个字母的组合,依次为AA到zz. 请问第2022列的名称是什么? 答案提交 这是一道结果填空的题,你只…

缓存一致性(cache coherency)解决方案:MESI 协议状态转换详解

MESI 协议 一,MESI状态释义二,MESI状态转换1 Invalid after Reset2, Invalid > Exclusive3, Exclusive > Modified4 Modified > Shared, Invalid > Shared5 Shared > Invalid, Shared > Modified 三,状态转换场景总结Inval…

最小生成树 | 市政道路拓宽预算的优化 (Minimum Spanning Tree)

任务描述: 市政投资拓宽市区道路,本着执政为民,节省纳税人钱的目的,论证是否有必要对每一条路都施工拓宽? 这是一个连问带答的好问题。项目制学习可以上下半场,上半场头脑风暴节省投资的所有可行的思路&a…

因果引擎(Causal Engine)是基于因果推理的人工智能系统

因果引擎(Causal Engine)是一种基于因果推理的人工智能系统。 其关键思想是通过学习事件之间的因果关系,对环境进行模型化和推理,从而指导AI系统采取行动。 因果引擎的主要特征包括: 建立因果图(Causal Graph):通过统计方法学习不同事件之间的因果关系,构建表示这些因果关系的…

基于微信小程序的游戏账号交易买卖平台设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言系统主要功能:具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序(小蔡coding)有保障的售后福利 代码参考源码获取 前言 💗博主介绍:✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计…

通过 Azure 日志分析加强云安全

Microsoft Azure 云服务在安全日志存储、访问、可伸缩性、降低成本和易于部署方面提供了巨大的优势,因此在企业中很受欢迎。 Microsoft Azure 日志记录工具(如 Log360)可帮助管理 Azure 云基础结构中所有设备和应用程序(如虚拟机…

Linux:nginx---web文件服务器

我这里使用的是centos7系统 nginx源码包安装 Linux:nginx基础搭建(源码包)_鲍海超-GNUBHCkalitarro的博客-CSDN博客https://blog.csdn.net/w14768855/article/details/131445878?ops_request_misc%257B%2522request%255Fid%2522%253A%25221…

Spring | 基于SpringBoot的多数据源实战 - 使用seata实现多数据源的全局事务管理

Spring | 基于SpringBoot的多数据源实战 - 使用seata实现多数据源的全局事务管理 引言1.1 多数据源的必要性1.2 多数据源的应用场景 实战演示2.1 创建实体类2.2 配置数据源2.3 实现数据源配置类2.4 配置Repository类2.5 运行与验证 事务管理与数据一致性3.1 事务管理3.2 使用Se…

长假,GPT来敲(Jué)门(Fén)

引 马上十一了,本拐在干了XX和XX事情以后,开始划水,欢天喜地的等放假。 然后,GPT4说更新了,据说加了一个读图的功能,本拐不以为然,不就是什么文生图,图生文么,TOOOLD。 不…

案例题-系统开发

案例题-系统开发 结构化分析方法概述面向对象分析方法真题1真题2 结构化分析方法概述 面向对象分析方法 了解一下符号就行 依赖关系:一个事务的变化影响另外一个事务的变化 泛化关系,父类子类 聚合:部分和整体之间的生命周期不同 组合&#x…

Cache系列直播,这次真的来了!

1、要学cache,一大堆一大堆待讨论的问题。例如近期的一些问题: L1、L2、L3 cache的替换策略是怎样的?什么类型的内存永远不会进L3 cache?L3 cache一般都是多大?L3 cache的组织形式一般是怎样的?什么是cache…

MySQL体系结构和四层架构介绍

MySQL体系结构图如下: 四层介绍 1. 连接层: 它的主要功能是处理客户端与MySQL服务器之间的连接(比如Java应用程序通过JDBC连接MySQL)。当客户端应用程序连接到MySQL服务器时,连接层对用户进行身份验证、建立安全连接并管理会话状态。它还处理…

医疗图像分割指标

医疗图像其中两种图像格式:MRI(Magnetic Resonance Imaging,磁共振成像)、CT(Computed Tomography,计算机断层),常存成 .nii.gz 格式。都是 3D 的 H W L H \times W \times L HWL…

数字孪生智慧能源:风光储一体化能源中心

自“双碳”目标提出以来,我国能源产业不断朝着清洁低碳化、绿色化的方向发展。其中,风能、太阳能等可再生能源在促进全球能源可持续发展、共建清洁美丽世界中被寄予厚望。风能、太阳能具有波动性、间歇性、随机性等特点,主要通过转化为电能再…

jvm内存分配与回收策略

自动内存管理 解决两个问题 自动给对象分配内存 对象一般堆上分配(而实际上也有可能经过即时编译后被拆散为标量类型并间接地在栈上分配) 新生对象通常会分配在新生代,少数情况下(例如对象大小超过一定阈值)也可能…

[H5动画制作系列 ]变量,帧频,监听器等的生命周期基础测试

模式:按照上述抓图,actions层,1帧,写初始化代码,10帧写返回代码到2帧代码,2-10帧之间一直循环。1帧及10帧代码如下: 如果程序在1-10之间循环,会反复创建变量i,多个监听器等。所以,第一帧最好执行一次即可,程序在2-10帧之间一直循环。

《Upload-Labs》01. Pass 1~13

Upload-Labs 索引前言Pass-01题解 Pass-02题解总结 Pass-03题解总结 Pass-04题解 Pass-05题解总结 Pass-06题解总结 Pass-07题解总结 Pass-08题解总结 Pass-09题解 Pass-10题解 Pass-11题解 Pass-12题解总结 Pass-13题解 靶场部署在 VMware - Win7。 靶场地址:https…

Leetcode290. 单词规律

给定一种规律 pattern 和一个字符串 s ,判断 s 是否遵循相同的规律。 这里的 遵循 指完全匹配,例如, pattern 里的每个字母和字符串 s 中的每个非空单词之间存在着双向连接的对应规律。 解题思路:哈希 力扣(LeetCode&…