本文部分援引于作者Hollis大神:原文链接
问题引出:
1、堆是线程共享的内存区域,栈是线程独享的区域。
2、堆主要存放对象实例,栈中主要存放各种基本数据类型、对象的引用。
以上两个结论其实不完全正确。
在解答之前,先想想Java 对象的内存分配过程是如何保证线程安全的?
对象的内存分配过程中,主要是对象的引用指向这个内存区域,然后进行初始化操作。
但是,因为堆是全局共享的,因此在同一时间,可能有多个线程在堆上申请空间,那么,在并发场景中,如果两个线程先后把对象引用指向了同一个内存区域,怎么办。
而Java对象的分配是Java中的高频操作,所有,人们想到另外一个办法来提升效率。这里我们重点说一个Hotspot虚拟机的方案:
每个线程在Java堆中预先分配一小块内存,然后再给对象分配内存的时候,直接在自己这块”私有”内存中分配,当这部分区域用完之后,再分配新的”私有”内存。
这种方案被称之为 TLAB 分配,即 Thread Local Allocation Buffer 。这部分 Buffer 是从堆中划分出来的,但是是本地线程共享的。