JVM內(nèi)存模型包括以下幾個部分:
1. 程序計數(shù)器(Program Counter Register)
程序計數(shù)器是一塊非常小的內(nèi)存區(qū)域,它可以看作是當(dāng)前線程所執(zhí)行的字節(jié)碼的行號指示器。在虛擬機中,程序計數(shù)器是線程私有的,每個線程都有自己獨立的程序計數(shù)器,各個線程之間的計數(shù)器互不影響。
2. Java堆(Java Heap)
Java堆是Java虛擬機所管理的內(nèi)存最大的一塊,它是被所有線程共享的內(nèi)存區(qū)域,存放所有的對象實例和數(shù)組。Java堆是垃圾收集器最重要的管理區(qū)域,也是Java內(nèi)存模型的核心部分。
3. 方法區(qū)(Method Area)
方法區(qū)也是被所有線程共享的一塊內(nèi)存區(qū)域,它存儲已被虛擬機加載的類信息、常量、靜態(tài)變量、即時編譯器編譯后的代碼等數(shù)據(jù)。方法區(qū)是垃圾收集器最重要的管理區(qū)域之一,如果方法區(qū)無法滿足新對象分配的需求,將拋出“OutOfMemoryError”異常。
4. Native方法棧(Native Method Stack)
Native方法棧也是虛擬機的一部分,用來執(zhí)行本地方法,也就是使用其他語言(如C/C++)編寫的方法。Java虛擬機執(zhí)行Java方法時,會將Java棧中的方法作為本地方法執(zhí)行,此時Java棧中對應(yīng)的棧幀會在Native方法棧中生成一個對應(yīng)的棧幀,當(dāng)Native方法執(zhí)行完畢后,棧幀會被銷毀。
5. Java棧(Java Stack)
每個線程在創(chuàng)建時都會創(chuàng)建一個Java棧,用于存儲線程執(zhí)行時所需的局部變量、操作數(shù)棧、動態(tài)鏈接、方法出口等信息。Java棧是線程私有的,各個線程之間的Java棧互不影響。
6. 堆外內(nèi)存(Off-heap Memory)
除了上述內(nèi)存區(qū)域以外,JVM還可以使用堆外內(nèi)存(Off-heap Memory),也稱為Direct Memory。堆外內(nèi)存是在虛擬機以外的內(nèi)存中分配的,它通常用于存儲大量的數(shù)據(jù),而且在垃圾收集器的管理之外。使用堆外內(nèi)存可以減輕Java堆的壓力,但需要開發(fā)人員手動申請和釋放內(nèi)存,因此使用堆外內(nèi)存需要更加謹(jǐn)慎。