Java代码是如何运行的
-
为什么使用jvm
可以轻松实现java代码的跨平台执行。
jvm提供一个托管平台,提供内存管理、垃圾回收、编译时动态校验等 -
java代码首先编译成class文件,然后通过java虚拟机加载到方法区,java虚拟机是一个独立的进程,执行方法区的方法
-
java虚拟机吧内存分为堆栈两种形式来存储运行时数据,包括线程共有的方法区和堆,线程私有的pc计数器、方法栈、native栈
-
java虚拟机将字节码翻译成机器码执行的方法有两种:
解释执行:即逐条将字节码翻译成机器码并执行、无需保存不占内存
编译执行:即将一个方法的所有的字节码编译成机器码后在执行、类似于预编译,编译之后的指令存在内存中,耗内存。
解释执行的好处是无需等待编译,即时编译的好处执行速度更快,这里编译的概念不是代码编译成java字节码,而是字节码编译成机器码,字节码编译成机器码是java虚拟机在运行程序的时候才去做的。所以是运行时候的开销,热点代码是通过即时编译来执行的。 -
即时编译原理建立在程序二八定律基础上,即百分之二十的代码占用百分之八十的计算量
热点代码编译之后放入内存重复执行,而其他运行次数较少的代码解释执行,避免占用过多内存。 -
Hotspot内置了多个即时编译器,包括C1、C2和Graal
热点代码的两种算法,基于采样的热点探测和基于计数器的热点探测,一般采用都是计数器的热点探测,基于计数器的热点探测又有两个计数器:方法调用计数器、回边计数器。在C1和C2中有不同的阈值。 -
jvm在考虑做AOT (ahead of time compilation) ,AOT可以在线下将字节码转换成机器码,用来结局应用启动性能不好的问题
-
c++和java的区别
c++的策略是直接编译成目标架构的机器码。java的策略是编译成一个虚拟架构的机器码,这个虚拟架构可以有物理实现(java processor)。也可以是软件实现。也就是所谓的JRE.
dmesg -T | grep “(java)”
可以查询jvm崩了引起的原因