在TLAB(线程本地分配缓存)上分配对象

目录

使用TLAB性能差异

示例

分配策略

Java对象分配过程


      JVM的Thread Local Allocation Buffer,即TLAB线程本地分配缓存,作用是加速分配对象空间,以前的日志里说到对于一些线程私有的对象,由于不会发生对象逃逸,所以JVM会以栈上分配的方式将对象空间分配到栈空间中,这样当方法调用完成后对象就会因离开了作用域而跟着一起被销毁,不需要等待GC来回收,而对于一些会发生逃逸的对象,例如类的成员变量,因为它们可能被其他线程访问,所以JVM会将其分配在堆空间中。但是,JVM堆空间是全局共享的,如果某些情况下出现许多线程不停分配对象在堆空间中(堆空间分配对象内存操作是同步操作),会降低程序的运行效率,为了解决该问题,JVM为每一个线程在初始化时先单独分配一块Buffer,该空间是线程私有的,当线程执行时需要为对象分配内存时,就是用自己的Buffer空间分配,这样就解决了多线程因共用同一JVM堆空间而产生的同步操作冲突问题。要注意的是,TLAB使用的堆内存空间其实还是eden区的,即新生代对象初始化时存放的eden区,也就是说,TLAB只是让每一个线程有自己私有的指针,分配对象内存时使用自己的私有的指针,别的线程无法利用这片区域,为对象分配完内存后,在整个eden区内无论哪个线程分配的对象都还是所有其他线程可访问的(感觉这里表述的不太好,总的来说就是,TLAB给了线程私有的分配空间的权利,这样就不会出现多线程使用同一堆空间分配对象空间时,因每一次分配都要同步操作而影响了程序执行效率。但是线程分配空间的对象在堆空间eden区内还是其他线程可见的)。如果TLAB一开始为线程分配的Buffer用

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值