从0开始的java复习生活——jvm

JVM

JVM内存结构:
方法区类、常量、静态变量、已编译的代码的存放位置;

类创建对象实例和数组存放位置,存放内容物理不连续,逻辑连续;如果堆中没有内存完成实例的分配,且无法扩展到足够的内存时,报错OutOfMemoryError

虚拟机栈:存放了4类8种数据类型和对象应用以及指向形对象;,线程需要的运行空间;栈帧:每个方法需要使用的内存(参数,局部变量,返回地址);每个线程只能有一个活动栈帧,对应正在执行的代码;如果存在线程请求的栈深度大于虚拟机所允许的深度,报错StackOverflowError;如果栈中可以进行动态扩展,而无法扩展到足够的内存时,报错OutOfMemoryError

程序计数器:线程私有,每个线程都有单独的一个程序计数器,只是记住下一个jvm指令的地址。唯一一个不会发生内存溢出。

本地方法栈:与虚拟机栈类似,服务的对象不同。

运行时常量池:方法区的一部分,存放编译器生成的字面量(例如:int=8等号右边为直接的数字字符)和符号的引用(string=“a”)内存无法申请时抛出OutOfMemoryError

注:方法区和堆、执行引擎,本地接口共享线程数据,而虚拟机栈,本地方法栈,程序计数器存在线程隔离

对象的创建
对象创建时,首先检查常量池中有无相对应的引用,如果有,检查其是否被加载解析初始化过,如果没有再进行类加载流程。

类加载通过之后,给新创建的对象分配内存(内存的大小在类加载完成之后便可以确认),在堆的空闲内存中划分一块区域(‘指针碰撞-内存规整’或‘空闲列表-内存交错’的分配方式 )。内存空间分配完成后,初始化为0,然后开始填充对象头(哈希码,对象的GC分代年龄等),然后执行int方法后才是真正对象创建。

对象的内存布局

对象头:存储自身运行数据,如哈希码、GC 分代年龄、锁状态标志、线程持有的锁、偏向线程 ID、偏向时间戳等,32 位虚拟机占 32 bit,64 位虚拟机占 64 bit。官方称为 ‘Mark Word’。第二部分是类型指针,即对象指向它的类的元数据指针,虚拟机通过这个指针确定这个对象是哪个类的实例。另外,如果是 Java 数组,对象头中还必须有一块用于记录数组长度的数据,因为普通对象可以通过 Java 对象元数据确定大小,而数组对象不可以。

实例数据:程序代码中所定义的各种类型的字段内容(父类继承和子类定义的)

对齐填充:非必要,占位,对象大小是某个字节的整倍数

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值