深度解析JVM面试关键:字节码、内存管理与调优

需积分: 0 0 下载量 115 浏览量 更新于2024-08-04 收藏 738KB PDF 举报
"Java虚拟机相关的面试问题涵盖了JVM的基础概念、字节码、运行时数据区、内存管理、垃圾收集器、性能监控以及JVM工具的使用等核心知识点。" 1. **JVM(Java Virtual Machine)**是Java语言的执行引擎,它将Java编译后的字节码转换为机器码,实现跨平台的运行。 2. **JDK与JVM的区别**:JDK(Java Development Kit)是Java开发工具集,包含了JVM、编译器、调试工具和其他开发者需要的工具;JVM仅是JDK的一部分,负责执行Java程序。 3. **JVM厂商**:主要包括Oracle(Sun Microsystems)、IBM、Azul Systems、OpenJDK等。 4. **Oracle JDK与OpenJDK**:Oracle JDK是商业版本,提供额外的性能优化和企业级特性,而OpenJDK是开源项目,两者在许可证和部分功能上有所差异。 5. **开发与生产环境选择JDK版本**:开发中通常选择最新稳定版,以利用新特性和性能提升;生产环境中,考虑到稳定性和兼容性,可能会选择长期支持(LTS)版本。 6. **Java字节码**是Java源代码编译后的二进制表示,包含类信息、常量池、字段和方法定义等。 7. **常量池**存储类中的常量、字符串、符号引用等,优化了程序的运行效率。 8. **运行时数据区**包括堆内存、栈内存、方法区、本地方法栈和程序计数器,各区域有其特定作用,如堆内存用于存放对象实例,栈内存处理方法调用。 9. **堆内存**分为新生代(Young Generation)和老年代(Old Generation),新生代又分为Eden区、From Survivor和To Survivor区,用于垃圾收集的分代策略。 10. **非堆内存**主要指方法区(在Java 8后被元空间(Metaspace)取代)和JVM自身运行所需的内存。 11. **内存溢出(Out of Memory)**是指应用程序在申请内存时,没有足够的内存空间供其使用,导致程序崩溃。 12. **内存泄漏**是指程序在申请内存后,无法释放已不再使用的内存空间,长时间累积会导致可用内存逐渐减少。 13. **垃圾收集(GC)**是JVM自动回收内存的过程,包括串行、并行、并发和增量等不同收集策略。 14. **Java8默认的垃圾收集器**是CMS(Concurrent Mark Sweep),Java11默认改为G1(Garbage-First)。 15. **G1收集器**是基于分区的垃圾收集器,目标是实现低延迟,通过预测暂停时间来控制垃圾收集。 16. **CPU使用率飙升**和**系统响应变慢**的排查通常涉及分析线程状态、内存使用、系统调用、日志等,通过工具如jstack、jmap、top、iostat等进行诊断。 17. **系统性能衡量**指标通常包括CPU使用率、内存利用率、I/O性能、网络吞吐量等。 18. **JVM工具**如jps用于查看Java进程,jstat监控JVM统计信息,jmap用于内存映射,jhat或VisualVM进行堆内存分析,jinfo配置JVM参数,jconsole提供GUI监控等。 19. **内存Dump**时需注意避免过大文件导致硬盘空间不足,以及正确选择分析工具如MAT(Memory Analyzer Tool)进行分析。 20. **遇到的JVM问题**可能涉及内存溢出、性能瓶颈、垃圾收集问题等,解决时需要结合日志、监控和代码审查进行排查优化。 面试时,对这些问题的深入理解和实践经验,将展示你的Java技术功底和问题解决能力。