1.简介
Java平台可分为两部分,即Java虚拟机(Java virtual machine,JVM)和Java API类库。
JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM使得Java实现了跨平台。
(字节码),就可以在多种平台上不加修改地运行。
2. JVM架构图
Java虚拟机主要分为五大模块:类装载器子系统、运行时数据区、执行引擎、本地方法接口和垃圾收集模块。
各部分的主要功能:
类加载器 :JVM启动,程序开始执行时,负责将class字节码加载到JVM内存区域中
执行引擎 :负责执行class文件中包含的字节码指令
本地方法库 :主要是调用C或C++实现的本地方法及返回结果
运行时数据区【重点关注】
方法区(Method Area) :用于存储类结构信息的地方,包括常量池、静态变量、构造函数等。
java堆(Heap) :存储java实例或者对象的地方。这块是GC的主要区域。方法区和堆是被所有java线程共享的。
java栈(Stack) :java栈总是和线程关联在一起,每当创建一个线程时,JVM就会为这个线程创建一个对应的java栈。在这个java栈中又会包含多个栈帧,每运行一个方法就创建一个栈帧,用于存储局部变量表、操作栈、方法返回值等。每一个方法从调用直至执行完成的过程,就对应一个栈帧在java栈中入栈到出栈的过程。所以java栈是现成私有的。
程序计数器(PC Register) :程序计数器是一块较小的内存空间,可以看作是当前线程所执行的字节码的行号指示器。分支、循环、跳转、异常处理、线程恢复等基础功能都需要依赖这个计数器来完成。
本地方法栈(Native Method Stack) :和java栈的作用差不多,只不过是为JVM使用到的native方法服务的。
3. JVM内部模块间的关系
垃圾回收系统:方法区、Java堆
类加载器:方法区、Java堆
执行引擎:方法区、Java堆、Java栈、PC寄存器
摘录自
https://note.youdao.com/ynoteshare1/index.html?id=920f10f97acfc22fe0c27cc52a97cb28&type=note
【Java面试整理之JVM】深入理解JVM结构、类加载机制、垃圾回收GC原理、JVM内存分配策略、JVM内存泄露和溢出