1. 什么是常量池?
常量池是 class 文件(.class)的一部分。常量池中包含了 .class 中的代码运行所需要的常量。
2. 什么是运行时常量池?
class 文件(.class)会将所有的符号引用放在一个地方,这个地方就是常量池。每个 class 文件都有一个常量池,并且当虚拟机加载类和接口时会生成一个相应的内部版本的常量池,这个常量池被称为运行时常量池。运行时常量池是一种数据结构,是 class 文件常量池在虚拟机中的具体实现。因此,当一个类型在虚拟机中加载完成,类型中所有的符号引用都会进入该类型的常量池中。JDK 8 之前,运行时常量池在虚拟机的方法区中,此外运行期间也可能将新的常量放入池中。
3.什么是 GC 停顿(Stop The World)?
JVM 在进行可达性分析时,为了确保过程中对象的引用关系不发生变化,会停顿所有 Java 执行线程。枚举根节点时必须要停顿。
4. 什么是 OopMap
?
OopMap
是一种数据结构,用来记录对象引用在虚拟机栈中的位置。它的主要目的是找到虚拟机栈中的 GC roots 并且当堆中的对象移动时更新相应的引用。在 HotSpot 的实现中,在类加载完成的时候,HotSpot 就把对象内什么偏移量上是什么类型的数据计算出来,在 JIT 编译过程中,也会在特定的位置记录下栈和寄存器中哪些位置是引用。
5. 什么是安全点?GC 什么时候开始运行?
HotSpot 为了节省内存不会为每条指令都生成对应的 OopMap
,而是在“特定的位置”记录了这些信息,这些位置称为安全点,即 JVM 并不是随时停顿下来开始 GC,而是在到达安全点时才开始 GC。
6. 局部变量表内存空间的分配时期
在编译时期,局部变量表在栈帧中如何占用的内存空间就会完成分配,在程序的运行时期不会改变局部变量表的大小。
7. Java 虚拟机堆和虚拟机栈的创建时期
- 虚拟机栈是线程私有的,在线程启动的时候创建。
- 虚拟机堆是线程共享的,在虚拟机启动时创建 。
8. Java 有哪些引用类型
- class types
- interface types
- type variables
- array types
9. 什么是序列化和反序列化?
- 序列化就是将数据结构和对象转换为二进制数据的过程。
- 反序列化就是将二进制数据转换为数据结构和对象的过程。
10. 对象头中包含哪些信息?
虚拟机中的对象头包含对象所属的类信息、如何找到类的元数据信息、对象的哈希码、对象的 GC 分代年龄信息等。