一、JDK体系结构
jre:Java运行时环境,支撑Java运行的核心类库和Java虚拟机。
jdk:Java完整程序包
二、JVM整体架构
跨平台特性:一次编写各个平台运行,不同机器不同的二进制机器码,依靠的是不同操作系统不同版本的JVM
运行过程:类转载子系统将.class字节码文件装载到运行时数据区,字节码执行引擎运行内存中的代码。
-
栈(线程)(虚拟栈):程序运行时虚拟机为运行时的线程开辟的独立内存空间用来存放运行线程的信息,Java方法执行的内存模型。
- 帧栈:每调动到一个方法都有对应的一块帧栈内存区域,存放方法的局部标量内存空间。压栈出栈
- 栈特性:FILO-先进后出
- 帧栈组成部分:局部变量表(局部变量-指向堆中的对象)、操作数栈(运算时临时中转内存)、动态链接、方法出口(标识执行完返回的要执行的方法)
- 扩展1:javap -c XXX.class > XXX.txt
-
本地方法栈:本地库函数,语言实现,存放本地方法运行空闲。
-
堆:运行时数据存储空间,用来存储对象本身的以及数组(当然,数组引用是存放在Java栈中的)
-
程序计数器:每个线程独有,存放当前线程运行号。保证多线程下代码有序运行。动态变化-字节码执行引擎修改程序计数器的值。
扩展:紫色为线程独有,黄色为共享
三、堆内存详解
- 垃圾回收由字节码执行引擎执行。
- minor GC垃圾执行过程:
从GC root出发利用可达性分析算法将引用的对象放进s0区,没有被引用的对象在eden区被清除。再次放满时,Eden区和s0区同时进行,将回收后存留的对象放进s1区。再次放满时,Eden区和s1区同时进行,将回收后存留的对象放进s0区。15次GC还存活的对象存储在老年代。 - full GC回收整个堆空间
分代年龄:经历过一次GC还存活对象分代年龄+1,存储在对象头
web应用在老年代存活的对象:静态变量引用的对象,数据库连接对象,连接池对象,spring容器的bean,Service,Controller
JVM调优诊断工具:jvisualvm
扩展资料:JVM的内存区域划分