解決方案一:對分配的內(nèi)存空間的動作進行同步處理。實際上虛擬機采用CAS配上失敗重試的方式保證更新操作的原子性。解決方案二:把內(nèi)存分配的動作按照線程劃分在不同的空間之中進行,即每個線程在Java堆中預(yù)先分配一小塊內(nèi)存,即本地線程分配緩沖(Thread Local Allocation Buffer,TLAB),哪個線程要分配內(nèi)存,就在哪個線程的TLAB上分配,只有TLAB用完并分配新的TLAB時,才需要同步鎖定,。虛擬機是否使用TLAB,可以通過-XX:+/-UseTLAB參數(shù)來設(shè)定。