博客
关于我
在TLAB(线程本地分配缓存)上分配对象
阅读量:334 次
发布时间:2019-03-03

本文共 665 字,大约阅读时间需要 2 分钟。

JVM的Thread Local Allocation Buffer(TLAB)是一种优化技术,旨在提升多线程环境下的内存分配效率。传统的分配方式在多线程环境下会导致频繁的同步操作,影响性能。TLAB通过为每个线程分配私有缓存空间,解决了这一问题。

TLAB的作用

TLAB的主要作用是为每个线程分配私有内存缓存,用于存放新对象的分配指针。由于线程私有的分配空间不会发生对象逃逸,JVM将其优化为栈分配方式。当线程终止时,这些对象会自动回收,无需等待GC。对于可能发生逃逸的对象,JVM仍会将其分配到共享的堆空间(eden区),确保其他线程也能访问这些对象。

使用TLAB的性能差异

TLAB默认启用,可以通过参数-XX:-UseTLAB关闭。启用TLAB的程序通常在内存分配速度上更快,特别是在多线程环境下。关闭TLAB时,所有线程都将共享同一堆空间,频繁的同步操作会显著增加程序开销。

分配策略

TLAB的分配策略基于对象大小和线程需求。对于小对象,若TLAB空间足够,直接分配到线程的私有缓存中。若空间不足或对象过大,JVM会将其分配到堆空间。TLAB的分配是动态的,线程会根据需求申请和释放空间。JVM内部通过refill_waste参数控制空间浪费比例,确保合理分配。

Java对象分配过程

JVM的对象分配流程从栈优先分配开始,若对象可能逃逸则分配到堆中。若不符合栈分配条件,进入TLAB分配。若TLAB空间不足,进入慢分配模式,直接分配到堆空间。对于大对象,直接进入老年代分配。整个流程确保了内存分配的效率和正确性。

转载地址:http://sstm.baihongyu.com/

你可能感兴趣的文章
OK335xS UART device registe hacking
查看>>
ok6410内存初始化
查看>>
Okhttp3添加拦截器后,报错,java.io.IOException: unexpected end of stream on okhttp3.Address
查看>>
OKR为什么到今天才突然火了?
查看>>
ollama-python-Python快速部署Llama 3等大型语言模型最简单方法
查看>>
ollama本地部署DeepSeek(Window图文说明)
查看>>
On Error GOTO的好处
查看>>
onclick事件的基本操作
查看>>
onCreate()方法中的参数Bundle savedInstanceState 的意义用法
查看>>
OneASP 安全公开课,深圳站, Come Here, Feel Safe!
查看>>
OneBlog Shiro 反序列化漏洞复现
查看>>
one_day_one--mkdir
查看>>
ONI文件生成与读取
查看>>
onlyoffice新版5.1.2版解决中文汉字输入重复等问题
查看>>
oobbs开发手记
查看>>
OPEN CASCADE Curve Continuity
查看>>
Open Graph Protocol(开放内容协议)
查看>>
Open vSwitch实验常用命令
查看>>
Open WebUI 忘了登入密码怎么办?
查看>>
open-vm-tools-dkms : 依赖: open-vm-tools (>= 2:9.4.0-1280544-5ubuntu3) 但是它将不会被安装
查看>>