这是后端面试集锦第十八篇博文——JVM
面试话术❗❗❗
1. 介绍下JVM
JVM
主要包括:类加载器(class loader
)、执行引擎(exection engine
)、本地接口(native interface
)、运行时数据区(Runtimedata area
)
-
类加载器:加载类文件到内存。
Class loader
只管加载,只要符合文件结构就加载,至于能否运行,它不负责,那是由执行引擎负责的。 -
执行引擎:负责解释命令,交由操作系统执行。
-
本地接口:本地接口的作用是融合不同的语言为
java
所用。 -
JVM
的运行时数据区分为五个区域:-
堆、虚拟机栈、本地方法栈、方法区、程序计数器。
-
其中虚拟机栈、本地方法栈、程序计数器为线程私有。
-
方法区和堆为线程共享区,
JVM
不同区域的占用内存大小不同,一般情况下堆内存最大,程序计数器较小。
-
-
程序计数器
-
这里记录了线程执行的字节码的行号,在分支、循环、跳转、异常、线程恢复等都依赖这个计数器。
-
如果线程正在执行的是一个
java
方法,这个计数器记录的是正在执行的虚拟机字节码指令地址。
-