总体框架
一、JVM的组成
1.1 JVM由那些部分组成,运行流程是什么?
JVM
是什么?
Java Virtual Machine Java
程序的运行环境(
java
二进制字节码的运行环境好处:
- 一次编写,到处运行
- 自动内存管理,垃圾回收机制
从图中可以看出 JVM 的主要组成部分:
- ClassLoader(类加载器)
- Runtime Data Area(运行时数据区,内存分区)
- Execution Engine(执行引擎)
- Native Method Library(本地库接口)
运行流程:
(1
)类加载器(
ClassLoader
)把
Java代码转换为字节码。
(2
)运行时数据区(
Runtime Data Area)把字节码加载到内存中,而字节码文件只是JVM的一套指令集规范,并不能直接交给底层系统去执行,而是有执行引擎运行。
(3
)执行引擎(
Execution Engine
)将字节码翻译为底层系统指令,再交由CPU执行去执行,此时需要调用其他语言的本地库接口(Native Method Library)来实现整个程序的功能。
1.2 什么是程序计数器?
程序计数器:线程私有的,内部保存的字节码的行号。用于记录正在执行的字节码指令的地址。
java虚拟机对于多线程是一个通过线程轮流切换并且分配线程执行时间。在任何的一个时间点上,处理器只会处理执行一个线程,如果当前被执行的这个线程它所分配的执行时间用完了【挂起】。处理器会切换到另外的一个线程上来进行执行。并且这个线程的执行时间用完了,接着处理器就会又来执行被挂起的这个线程。
那么现在有一个问题就是,当前处理器如何能够知道,对于这个被挂起的线程,它上一次执行到了哪里?那么这时就需要从程序计数器中来回去到当前的这个线程他上一次执行的行号,然后接着继续向下执行。
程序计数器是JVM规范中唯一一个没有规定出现OOM的区域,所以这个空间也不会进行GC。
1.3 你能给我详细的介绍Java堆吗?
线程共享的区域:主要用来保存对象实例,数组等,当堆中没有内存空间可分配给实例,也无法再扩展时,则抛出OutOfMemoryError