- 解释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;