博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JIT
阅读量:7042 次
发布时间:2019-06-28

本文共 831 字,大约阅读时间需要 2 分钟。

hot3.png

Java JIT(just in time)即时编译器是sun公司采用了hotspot虚拟机取代其开发的classic vm之后引入的一项技术,目的在于提高java程序的性能,改变人们“java比C/C++慢很多”这一尴尬印象。

说起来是编译器,但此编译器与通常说的javac那个编译器不同,它其实是将字节码编译为硬件可执行的机器码的。

图片来自于网络

如上图可以看出,整个java应用程序的执行过程如下:

1、源代码经javac编译成字节码,class文件

2、程序字节码经过JIT环境变量进行判断,是否属于“热点代码”(多次调用的方法,或循环等)

3、如是,走JIT编译为具体硬件处理器(如sparc、intel)机器码

4、如否,则直接由解释器解释执行

5、操作系统及类库调用

6、硬件

以上实际上是JVM的“混合模式”对java程序的执行方式。

 

jvm还有两种执行方式: 解释执行和编译执行

      对于解释执行,不经过jit直接由解释器解释执行所有字节码,执行效率不高。 而编译执行不加筛选的将全部代码进行编译机器码不论其执行频率是否有编译价值,在程序响应时间的限制下,编译器没法采用编译耗时较高的优化技术(因为JIT的编译是首次运行或启动的时候进行的!),所以,在纯编译执行模式下的java程序执行效率跟C/C++也是具有较大差距的。

因此,新版本的jvm默认都是采用混合执行模式。

 

     这里有个特别的例子,BEA公司为服务器硬件和服务端应用专门打造的高度优化的虚拟机————jrockit,由于面向服务端应用,所以它并不在意和关注程序的启动速度,jrockit并不实现解释器,而是将所有代码都交由jit做即时编译执行。

 

     jit并不一定总能提高程序的执行效率甚至适得其反,这很大一部分取决于开发人员所写的程序质量,作为优秀的工程师应该会写出对jit友好的程序。

转载于:https://my.oschina.net/javahongxi/blog/1523780

你可能感兴趣的文章
HDOJ-2546 饭卡【DP】【01背包】
查看>>
币值转换
查看>>
POJ 2728 Desert King (算竞进阶习题)
查看>>
(转)heX——基于 HTML5 和 Node.JS 开发桌面应用
查看>>
通过腾讯地图api获取用户位置限制在指定位置区域
查看>>
Archlinux GRUB2 配置
查看>>
第二周作业
查看>>
团队事后分析
查看>>
mysql 关于列的语句
查看>>
博客作业2---线性表
查看>>
grub2引导安装kali2.0及安装ibus拼音输入法
查看>>
SQL常用命令
查看>>
Linux~Docker部分~
查看>>
Simple2D-15(音乐播放器)使用 glfw 库
查看>>
web.config 配置与获取
查看>>
据说每个大牛、小牛都应该有自己的库——DOM处理
查看>>
装饰器学习
查看>>
Mongodb Windows 集群
查看>>
linux 上查找pid,筛选出来
查看>>
每天一总结
查看>>