TLAB

2. TLAB

JVM在内存新生代Eden Space中开辟了一小块线程私有的区域,称作TLAB(Thread-local allocation buffer)。默认设定为占用Eden Space的1%。在Java程序中很多对象都是小对象且用过即丢,它们不存在线程共享也适合被快速GC,所以对于小对象通常JVM会优先分配在TLAB上,并且TLAB上的分配由于是线程私有所以没有锁开销。因此在实践中分配多个小对象的效率通常比分配一个大对象的效率要高。
也就是说,Java中每个线程都会有自己的缓冲区称作TLAB(Thread-local allocation buffer),每个TLAB都只有一个线程可以操作,TLAB结合bump-the-pointer技术可以实现快速的对象分配,而不需要任何的锁进行同步,也就是说,在对象分配的时候不用锁住整个堆,而只需要在自己的缓冲区分配即可。
关于对象分配的JDK源码可以参见JVM 之 Java对象创建[初始化]中对OpenJDK源码的分析。

3. Java对象分配的过程

  1. 编译器通过逃逸分析,确定对象是在栈上分配还是在堆上分配。如果是在堆上分配,则进入选项2.

  2. 如果tlab_top + size <= tlab_end,则在在TLAB上直接分配对象并增加tlab_top 的值,如果现有的TLAB不足以存放当前对象则3.

  3. 重新申请一个TLAB,并再次尝试存放当前对象。如果放不下,则4.

  4. 在Eden区加锁(这个区是多线程共享的),如果eden_top + size <= eden_end则将对象存放在Eden区,增加eden_top 的值,如果Eden区不足以存放,则5.

  5. 执行一次Young GC(minor collection)。

  6. 经过Young GC之后,如果Eden区任然不足以存放当前对象,则直接分配到老年代。

对象不在堆上分配主要的原因还是堆是共享的,在堆上分配有锁的开销。无论是TLAB还是栈都是线程私有的,私有即避免了竞争(当然也可能产生额外的问题例如可见性问题),这是典型的用空间换效率的做法。

ThreadLocal和TLAB是Java虚拟机(JVM)中与内存分配和线程相关的两个概念。 ThreadLocal是一个Java类,它提供了线程本地变量的功能。每个线程都可以拥有自己的ThreadLocal变量,该变量在不同的线程中具有不同的值。ThreadLocal的设计目的是为了在多线程环境中提供线程安全的对象,并且避免了使用锁的开销。ThreadLocal可以在多个线程之间独立保存变量,每个线程都可以独立访问和修改自己的ThreadLocal变量,而不会影响其他线程的值。这是通过在每个线程的Thread对象中维护一个ThreadLocalMap来实现的。ThreadLocal在某些情况下可以用于避免共享变量的并发访问问题,但需要谨慎使用,以避免内存泄漏。 TLAB(Thread Local Allocation Buffer)是JVM在分配新对象时使用的一种内存分配缓冲区。每个线程都拥有自己的TLAB,用于存储该线程分配的新对象。由于每个线程只能写入自己的TLAB,因此不需要同步操作,可以提高分配新对象的性能。TLAB默认情况下是启用的,可以使用启动参数-XX:-UseTLAB将其禁用。调整TLAB的大小可以通过-XX:ThreadLocalBufferSpace参数来实现。 总结来说,ThreadLocal是Java类库提供的一种机制,用于在多线程环境中实现线程安全的变量。而TLAB是JVM在内存分配过程中使用的一种优化机制,用于提高对象分配的性能。两者虽然都与线程相关,但是在不同的层面上发挥作用,ThreadLocal是应用层面的设计,而TLAB是JVM层面的内存优化。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [JVM线程本地分配缓冲区(Thread Local Allocation Buffer)TLAB详解](https://blog.csdn.net/zgz15515397650/article/details/119383089)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [开坑,深入理解jvm虚拟机系列](https://blog.csdn.net/qq_36779436/article/details/125391952)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值