一、執(zhí)行Java程序時(shí),內(nèi)存劃分:
1、程序計(jì)數(shù)器(Program Counter Register);
2、虛擬機(jī)棧(VM Stack);
3、本地方法棧(Native Method Stack);
4、方法區(qū)(Method Area);
5、堆(Heap);
1、程序計(jì)數(shù)器
當(dāng)前線程執(zhí)行字節(jié)碼的行號(hào)的指示器;
每條線程都有獨(dú)立的程序計(jì)數(shù)器;
Java方法記錄執(zhí)行的JVM字節(jié)碼指令地址;
Native方法為空。
2、虛擬機(jī)棧
線程私有;
每個(gè)方法執(zhí)行時(shí)產(chǎn)生一個(gè)棧幀,用于存儲(chǔ)局部變量表,操作數(shù)棧,動(dòng)態(tài)鏈接,方法出口等信息,執(zhí)行開(kāi)始到結(jié)束對(duì)應(yīng)入棧到出棧的過(guò)程。
3、本地方法棧
與虛擬機(jī)棧類似,執(zhí)行的是Native方法;
4、Java堆
所有線程共享;
GC管理的主要區(qū)域;
存放對(duì)象實(shí)例。
5、方法區(qū)
所有線程共享。
存儲(chǔ)已加載的類信息、常量、靜態(tài)變量、JIT后的代碼;
運(yùn)行時(shí)常量池
方法區(qū)的一部分,編譯生成的字面量和符號(hào)引用存放在常量池。
直接內(nèi)存
非JVM運(yùn)行時(shí)的數(shù)據(jù)區(qū)部分。