JVM运行时数据区及内存分配策略

运行时数据区

Java运行时数据区

运行时数据区也就是JVM运行时产生的数据存放的区域,这块区域就是JVM的内存区域,也称为JVM的内存模型–JMM

JMM分成了以下几部分:

  • 堆空间(线程共享):存放new出来的对象
  • 元空间(线程共享):存放类元信息、类的模板、常量池、静态部分。
  • 线程栈(线程独享):存放方法的栈帧
  • 本地方法区(线程独享):本地方法产生的数据
  • 程序计数器(线程独享):配合执行引擎来执行指令

内存分配策略

为对象分配内存,具体的分配策略如下:

  • Bump the pointer(指针碰撞):如果内存空间是绝对规整的,则JVM记录当前剩余内存的指针,然后为对象分配内存。
  • Free List(空闲列表):如果内存空间的分配不规整,那么JVM会维护一个可用内存空间的列表用于分配。

对象并发分配存在的问题:

  • Compare And Swap:自旋分配,如果并发分配失败则重试分配之后的地址。
  • Thread Local Allocation Buffer(TLAB):本地线程分配缓冲,JVM被每个线程分配一个空间,每个线程在自己的空间中创建对象(jdk8默认使用,之前版本需要通过-XX:+UseTLAB开启)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值