今天我们继续探讨常见的JVM面试题。这些问题不比之前的问题庞大,多用于面试中JVM部分的热身运动,开胃菜,但是大家已经要认真准备。
JRE、JDK、JVM 及JIT 之间有什么不同?
- JRE 代表Java 运行时(Java run-time),是运行Java 引用所必须的。
- JDK 代
表Java 开发工具(Java development kit),是Java 程序的开发工具,如Java
编译器, 它也包含JRE。JVM 代表Java 虚拟机( Java virtual machine), 它
的责任是运行Java 应用。 - JIT 代表即时编译( Just In Time compilation),当
代码执行的次数超过一定的阈值时, 会将Java 字节码转换为本地代码,如,主
要的热点代码会被转换为本地代码, 这样有利大幅度提高Java 应用的性能。
讲一讲JVM 选项-XX:+UseCompressedOops
当你将你的应用从32 位的JVM 迁移到64 位的JVM 时,由于对象的指针从
32 位增加到了64 位,因此堆内存会突然增加,差不多要翻倍。这也会对CPU
缓存(容量比内存小很多)的数据产生不利的影响。因为,迁移到64 位的JVM
主要动机在于可以指定最大堆大小, 通过压缩OOP 可以节省一定的内存。通过
-XX:+UseCompressedOops 选项,JVM 会使用32 位的OOP,而不是64 位
的OOP。
Serial 与Parallel GC 之间的不同之处?
Serial 与Parallel 在GC 执行的时候都会引起stop-the-world。它们之间主要
不同serial 收集器是默认的复制收集器,执行GC 的时候只有一个线程, 而
parallel 收集器使用多个GC 线程来执行。
什么是空闲列表
如果Java堆内存中的内存并不是规整的,已被使用的内存和空闲的内存相互交错在一起,不可以进行指针碰撞啦,虚拟机必须维护一个列表,记录哪些内存是可用的,在分配的时候从列表找到一块大的空间分配给对象实例,并更新列表上的记录,这种分配方式就是空闲列表。
64 位JVM 中,int 的长度是多数?
Java 中,int 类型变量的长度是一个固定值,与平台无关,都是32 位。意思就
是说,在32 位和64 位的Java 虚拟机中,int 类型的长度是相同的。
32/64 位JVM 的最大堆内存分别是多数?
理论上说上32 位的JVM 堆内存可以到达2^32,即4GB,但实际上会比这个
小很多。不同操作系统之间不同,如Windows 系统大约1.5 GB,Solaris 大约
3GB。64 位JVM 允许指定最大的堆内存,理论上可以达到2^64,这是一个非
常大的数字,实际上你可以指定堆内存大小到100GB。甚至有的JVM,如Azul,
堆内存到1000G 都是可能的。
往期文章
金三银四面试题(一):JVM类加载与垃圾回收
金三银四面试题(二):数据库缓存的数据一致性
金三银四面试题(三):JVM内存模型
金三银四面试题(四):Full GC 和 Minor GC
金三银四面试题(五):JVM之TLAB
金三银四面试题(六):对象大小知多少
金三银四面试题(七):JVM常见面试题(1)