JVM 四大组成部分
- 类加载器(ClassLoader)
- 运行时数据区(Runtime Data Area)
- 执行引擎(Execution Engine)
- 本地库接口(Native Interface)
1.1 基本信息
- JDK > JRE > JVM
- 堆 - Heap:运行时动态分配内存大小;GC 管理的主要区域
- 堆可扩展,当前主流的虚拟机都是按照可扩展来实现的(通过-Xmx和-Xms控制
- JVM Heap Configuration
- -Xms 初始堆大小
- -Xmx 最大堆大小
- 一般建议设置
-Xms = -Xmx
, 好处是避免每次在 GC 后,调整堆的大小,减少系统内存分配开销
2. JVM Runtime Data
2.1 Heap
- Java堆是被所有线程共享的一块内存区域,在虚拟机启动时创建
- 存放对象实例
- 是垃圾收集器管理的主要区域
2.2 Method Area
- 别名 Non-Heap(非堆)
- 方法区中包含的都是在整个程序中永远唯一的元素,如class,static变量
- 用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据
- 静态成员变量存储在方法区(方法区又叫静态区),非静态成员变量存储在堆区
2.2.1 Runtime Constant Pool
- 运行时常量池是方法区的一部分
- Class 文件中除了有类的版本、字段、方法、接口等描述信息外,还有一项信息是常量池(Constant Pool Table),用于存放编译期生成的各种字面量和符号引用,这部分内容将在类加载后进入方法区的运行时常量池中存放
2.3 JVM Stacks
- 虚拟机栈描述的是 Java 方法执行的内存模型:每个方法在执行的同时都会创建一个栈帧用于存储局部变量表、操作数栈、动态连接、方法出口等信息
- 每一个方法从调用直至执行完成的过程,对应着一个栈帧在虚拟机栈中入栈到出栈的过程
2.4 Native Method Stacks
- 本地方法栈与虚拟机栈的作用非常相似,它们的区别是虚拟机栈为虚拟机执行Java方法(也就是字节码)服务,而本地方法栈则为虚拟机使用到的Native方法服务
-
Native方法
就是一个 java 调用非 java 代码的接口,该方法并非 Java 实现的,可能由 C 或 Python等其他语言实现的, Java 通过 JNI 来调用本地方法, 而本地方法是以库文件的形式存放的
2.5 PC Register
- 指向当前线程正在执行的字节码指令的地址
- 行号指示器
概念名词
3.1 栈帧
- 当调用 Java 方法时,虚拟机会创建一个栈桢并压入 Java 栈,而当它调用的是本地方法时,虚拟机会保持 Java 栈不变,不会在 Java 栈帧中压入新的帧,虚拟机只是简单地
动态连接
并直接调用指定的本地方法

3.2 常量池
- 详解“符号引用转直接引用”
- Constant pool 即常量池,确切地说叫class文件常量池(常量池加载到方法区后就叫运行时常量池),它是class文件的一部分,用于保存编译时确定的数据
3.3 扩展知识
- 对象实例化:执行构造函数,在堆内存中为实例变量开辟空间,并赋予默认的初始值
- 实例变量只有在你调用了该类的实例时才会加载
- JNI(Java Native Interface),所谓本地方法就是一个 java 调用非 java 代码的接口,该方法并非 Java 实现的,可能由 C 或 Python等其他语言实现的, Java 通过 JNI 来调用本地方法, 而本地方法是以库文件的形式存放的(在 WINDOWS 平台上是 DLL 文件形式,在 UNIX 机器上是 SO 文件形式)



网友评论