java执行停顿,Java 知识小集 第 2 期

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 分代年龄信息等。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值