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