JVM 内存结构

12 篇文章 0 订阅

1、程序计数器

Java 虚拟机的多线程是通过线程轮流切换并分配处理器执行时间的方式实现,所以确定的时刻一个处理器只会执行一个线程中的指令。

为了线程切换后能恢复到正确的执行位置,每个线程都需要一个独立的程序计数器,用于记录线程所执行字节码指令的地址。

2、虚拟机栈

虚拟机栈是线程私有的。每个方法执行时会创建一个帧栈,用于存储局部变量表、操作数栈、动态链接、方法出口等信息。当方法调用时,栈帧入栈,方法结束时,栈帧出栈。

局部变量表的所需的内存空间在编译期间完成分配,运行时不会改变大小。

虚拟机栈定义了两种异常状况:StackOverFlowError 和 OutOfMemoryError 。

  • StackOverFlowError:线程请求的栈深度大于虚拟机所允许的深度。
  • OutOfMemoryError :大多数虚拟机都允许动态扩展虚拟机栈的大小,所以线程可以一直申请栈,直到内存不足时,抛出 OutOfMemoryError。

3、本地方法栈

本地方法栈为虚拟机使用到的 native 方法服务。Sun HotSpot 虚拟机直接把虚拟机栈与本地方法栈合二为一。与虚拟机栈一样,也会抛出 StackOverFlowError 和 OutOfMememoryError 异常。

4、Java 堆

Java 堆是垃圾收集器管理的主要区域,也称为 GC 堆。所有实例和数组都在这里分配内存,也是线程共享的内存区域。

-Xms 设置最小值;-Xmx 设置最大值。

5、方法区

与 Java 堆一样,也是线程共享的内存区域,用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译后的代码等数据。

在 HotSpot 虚拟机中,这块区域对应永久代,不易被回收。

运行时常量池:属于方法区一部分。用于存放编译期生成的常量和引用。

6、直接内存

直接内存并不是虚拟机内存的一部分,也不是 Java 虚拟机规范中定义的内存区域。jdk1.4 中新加入的 NIO,引入了通道与缓冲区的 IO 方式,它可以调用 Native 方法直接分配堆外内存,这个堆外内存就是本机内存,不会影响到堆内存的大小。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JaqenNg

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值