JVM面试

基本概念:

jvm是可运行Java代码的假想计算机,包括一套字节码指令集,一组寄存器,一个栈。一个垃圾回收,堆和一个存储方法域。JVM是运行在操作系统上的,它与硬件没有直接的交互

运行过程

我们都知道Java源文件,通过编译器,能够生产相应的.Class文件,也就是字节码文件,而字节码文件又通过Java虚拟机中的解释器,编译成特定的机器码。
也就是如下:
1、Java源文件-》编译器-》字节码文件
2、字节码文件-》JVM-》机器码
每种平台的解释器是不同的,但是实现的虚拟机是相同的,这就是Java为什么能够跨平台的原因,当另一个程序从开始运行,这时虚拟机就开始实例化了,多个程序启动就会存在多个虚拟机实例,程序包退出或者关闭,则虚拟机实例消亡,多个虚拟机实例之间数据不能共享
在这里插入图片描述
这里说的线程指程序执行过程中的一个线程实体.JVM允许一个应用并发执行多个线程。当线程本地存储,缓冲区分配、同步对象、栈、程序计数器等准备好以后,就会创建一个操作系统原生线程

### JVM面试常见问题及解答 #### 一、JVM内存区域划分 JVM的内存被划分为多个不同的区域,这些区域各自承担着特定的功能。具体来说,JVM会向操作系统申请一块连续的物理内存空间,并在此基础上进一步细分成若干逻辑部分[^3]。 - **方法区**:用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。 - **堆**:所有线程共享的一块区域,几乎所有的对象实例都在这里分配内存。这是垃圾收集器管理的主要区域。 - **栈**:每个线程创建时都会有一个独立的栈,保存局部变量表、操作数栈、动态链接、返回地址等信息。 - **本地方法栈**:与Java方法使用的栈相对应,服务于Native方法调用。 - **程序计数器**:记录当前线程执行字节码指令的位置;如果正在执行的是一个Java方法,则记录下一条要执行的指令地址;如果是native方法则为空。 #### 二、垃圾回收机制简介 在Java应用程序运行期间,随着新对象不断创建,可用内存逐渐减少。为了防止内存耗尽并提高性能,JVM提供了自动化的垃圾回收功能(GC)[^2]。其核心目的是识别不再使用的对象并将它们占用的空间重新收回给系统。这样做的好处在于简化了开发人员的工作流程——无需手动追踪每一个对象的生命期或担心因疏忽而导致资源泄漏等问题。 ##### 主要目标如下: - **清除无用对象**:通过周期性的扫描找出那些已经没有任何引用指向的对象,并将其标记为可清理状态; - **优化内存布局**:当某些区域内存在大量碎片化的小块未连贯空闲空间时,GC可以整理这些零散片段使之成为较大范围的整体空白区间以便后续高效利用; - **提升应用响应速度**:合理配置GC参数能够有效降低停顿时间从而改善用户体验。 ```java // 示例代码展示如何触发一次完整的Full GC过程 System.gc(); // 请求JVM尽快启动一次全局级别的垃圾收集动作 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值