博客
关于我
在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/

你可能感兴趣的文章
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>
mysql中的rbs,SharePoint RBS:即使启用了RBS,内容数据库也在不断增长
查看>>
mysql中的undo log、redo log 、binlog大致概要
查看>>
Mysql中的using
查看>>
MySQL中的关键字深入比较:UNION vs UNION ALL
查看>>
MYSQL中频繁的乱码问题终极解决
查看>>
Mysql主从不同步
查看>>
mysql主从同步及清除信息
查看>>
MySQL主从复制几个重要的启动选项
查看>>
MySQL主从架构与读写分离实战
查看>>
MySQL主从篇:死磕主从复制中数据同步原理与优化
查看>>
mysql主从配置
查看>>
MySQL之2003-Can‘t connect to MySQL server on ‘localhost‘(10038)的解决办法
查看>>
MySQL之CRUD
查看>>
MySQL之DML
查看>>
Mysql之IN 和 Exists 用法
查看>>
Mysql之主从复制
查看>>