Java 堆内存是线程共享的吗?

本文探讨了Java堆内存的线程共享特性,详细介绍了TLAB(Thread Local Allocation Buffer),它是Hotspot虚拟机为提升对象分配效率而引入的一种机制。TLAB是从堆内存的Eden区划出的线程独享空间,使得对象在分配时避免了并发控制,但并非完全线程隔离。文章讨论了TLAB带来的问题及解决方案,强调了小对象分配的高效性,并指出大对象可能仍需在堆内存中直接分配。
摘要由CSDN通过智能技术生成

本文部分援引于作者Hollis大神:原文链接

问题引出:

1、堆是线程共享的内存区域,栈是线程独享的区域。

2、堆主要存放对象实例,栈中主要存放各种基本数据类型、对象的引用。

以上两个结论其实不完全正确。

在解答之前,先想想Java 对象的内存分配过程是如何保证线程安全的?

对象的内存分配过程中,主要是对象的引用指向这个内存区域,然后进行初始化操作。

但是,因为堆是全局共享的,因此在同一时间,可能有多个线程在堆上申请空间,那么,在并发场景中,如果两个线程先后把对象引用指向了同一个内存区域,怎么办。

而Java对象的分配是Java中的高频操作,所有,人们想到另外一个办法来提升效率。这里我们重点说一个Hotspot虚拟机的方案:

每个线程在Java堆中预先分配一小块内存,然后再给对象分配内存的时候,直接在自己这块”私有”内存中分配,当这部分区域用完之后,再分配新的”私有”内存。

这种方案被称之为 TLAB 分配,即 Thread Local Allocation Buffer 。这部分 Buffer 是从堆中划分出来的,但是是本地线程共享的。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值