首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >什么是TLAB (线程本地分配缓冲区)?

什么是TLAB (线程本地分配缓冲区)?
EN

Stack Overflow用户
提问于 2017-05-03 05:05:26
回答 1查看 10.7K关注 0票数 40

我找不到一个全面的资源来清晰地解释这个概念。我的理解是,线程在分配新对象的伊甸园中被分配了一些内存块。一个相互竞争的线程最终将拥有一个有点连续的伊甸园。如果第一个线程耗尽了其TLAB中的空闲区域,会发生什么情况?它会请求一块新的伊甸园吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-05-03 14:50:24

TLAB的思想是减少线程之间的同步需求。使用TLABs可以减少这种需求,因为任何线程都有一个可以使用的区域,并且期望它是唯一使用该区域的线程。假设一个TLAB可以容纳100个对象,那么在分配101个对象时,线程只需要获取一个锁,就可以获得更多的内存。如果没有TLABs,这将是每个对象都需要的。当然,缺点是您可能会浪费空间。

大对象通常分配在TLAB之外,因为它们失去了降低同步内存分配频率的优势。有些对象甚至可能无法放入TLAB中。

您可以使用-XX:TLABSize标志设置TLAB的大小,但通常我不建议您修改这些设置,除非您真的发现了可以通过它解决的问题。

票数 49
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43747221

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档