一、JVM 的主要组成部分及其作用
JVM 主要由以下几个部分组成:
- 类加载器(ClassLoader):将 Java 代码转换为字节码。
- 运行时数据区(Runtime Data Area):加载字节码到内存。
- 执行引擎(Execution Engine):将字节码翻译成底层系统指令,交由 CPU 执行。
- 本地库接口(Native Interface)JNI:调用其他语言的本地库实现程序功能。
组件的作用:首先通过类加载器把 Java 代码转换成字节码,运行时数据区再把字节码加载到内存中,而字节码文件只是 JVM 的一套指令集规范,并不能直接交给底层操作系统去执行,因此需要特定的命令解析器执行引擎,将字节码翻译成底层系统指令,再交由 CPU 去执行,而这个过程中需要调用其他语言的本地库接口来实现整个程序的功能。
二、JVM 运行时数据区及各区域作用
JVM 运行时数据区包括以下部分:
- 程序计数器(Program Counter Register):当前线程所执行的字节码的行号指示器,字节码解析器通过改变这个计数器的值,选取下一条需要执行的字节码指令。
- Java 虚拟机栈(Java Virtual Machine Stacks):执行方法前创建栈帧,用于存储局部变量表、操作数栈、动态链接、方法出口等信息。执行方法时,栈帧入栈;执行完毕方法,栈帧出栈。
- 本地方法栈(Native Method Stack):与虚拟机栈作用类似,只不过虚拟机栈服务 Java 方法,本地方法栈为虚拟机调用 Native 方法服务。
- Java 堆(Java Heap):Java 虚拟机中内存最大的一块,被所有线程共享,几乎所有的对象实例都在这里分配内存。GC 垃圾回收相关参数:
-Xms
、-Xmx
。 - 方法区(Methed Area):用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译后的代码等数据。在 JDK 1.7 中,相关参数为
-XX:PermSize
、-XX:PermMaxSize
;在 JDK 1.8 中,相关参数为-XX:MetaspaceSize
、-XX:MetaspaceMaxSize
。