Java自动内存管理机制(二) 运行时数据区

本文详细介绍了Java的JVM运行时数据区,包括程序计数器、虚拟机栈、本地方法栈、Java堆和方法区,以及对象创建的流程、内存布局和定位方法。重点讨论了堆内存的分配、对象头的组成以及对象访问的两种方式。
摘要由CSDN通过智能技术生成

学习这部分,有图胜千字

JVM Runtime Area

运行时数据区。JVM在执行Java程序过程中会把它所管理的内存划分为若干个不同的数据区域。
大家都用这张图:
这里写图片描述

  • 程序计数器:(program counter register)。一块很小内存空间,可看做是当前线程所执行的字节码的行号指示器。线程私有,每个线程的PC记录了当前线程要执行的指令。若当前线程执行的是Java方法,其PC值记录的是正在执行的虚拟机字节码指令的地址;若执行的是本地方法(native method),则PC为空(Undefined)。唯一一个没有规定任何OutOfMemoryError的区域
  • Java虚拟机栈(VM Stack):线程私有,与线程生命周期相同。描述的是Java方法执行的内存模型:每个方法在执行的同时都会创建一个栈帧(Stack Frame)用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每一个方法从调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中入栈到出栈的过程。对应2个异常:StackOverflowError。和OutOfMemoryError.
  • 本地方法栈
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值