JVM(1)

  • 解释Java为什么能够跨平台?

Java的源文件通过编译生成字节码文件,字节码文件又通过解释器解释为特定机器的机器码。每一个平台的解释器是不同的,但实现的虚拟机是相同的。

  • JVM的线程与操作系统的线程有什么关系?

一个JVM就是一个进程,JVM的线程与操作系统的线程有直接的映射关系,当线程本地存储,缓冲区分配,同步对象,栈,程序计数器准备好之后,就会创建一个操作系统原生线程。原生线程初始化之后,就会调用run方法,线程结束后,会释放原生线程和Java线程的所有资源。

  • JVM的后台进程有哪些?

GC进程,VM进程,等待到达安全点执行。

  • OOM,OutOfMemoryError出现的原因有哪些?

堆不能分配对象,栈不能分配栈帧,方法区不能分配内存等,常量池不能分配内存。

  • JVM内存区域的存活周期是怎样的?

线程私有的存活依赖于线程的存活。线程共享的存活依赖于虚拟机的启动与关闭。

栈帧的存活周期是在方法调用是入栈,在方法完成时出栈,无论是正常完成还是抛出异常完成。

  • 程序计数器存储的内容是什么?

存储当前线程所执行的字节码的行号指示器。正在执行Java时,保存的是字节码指令的地址,执行本地方法时为空。

  • 方法区做不做垃圾回收?

一般是对常量池的回收和类型的卸载。收益较低。

  • 对常量池有没有了解?

Java中的常量池有3中,class静态常量池,运行时常量池和字符串常量池。

字符串常量池是全局的。StringTable类的实例。用hashMap保存。

其中,在编译期间,将字面量和符号引用保存在静态常量池。

在加载期间,将静态常量池转为运行时常量池。运行时常量池是每个类有一个。

在解析后,如果字符串常量池存在运行时常量池中的字符串,则把字符串常量池中的直接引用赋给运行时常量池。如果字符串常量池不存在,则新建一个String对象,将引用添加到字符串常量池和运行时常量池。

在程序运行过程中,遇到“”则像上面一样判断字符串常量池。

1.7

符号引用(Symbols)转移到了native memory;字符串常量池(interned strings)转移到了Java heap;类的静态变量(class statics variables )转移到了Java heap;

1.8 移除永久代换为元空间。

永久代中的 class metadata 转移到了 native memory(本地内存,而不是虚拟机);
永久代中的 interned Strings 和 class static variables 转移到了 Java heap;

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值