根據(jù)《Java虛擬機規(guī)范(第二版)》的規(guī)定,結(jié)構(gòu)如下
1)程序計數(shù)器
Program Counter Register
是一小塊內(nèi)存空間,他的作用是當(dāng)前線程所執(zhí)行的行號指示器。此內(nèi)存區(qū)是唯一一個沒有規(guī)定OutOfMemoryError情況的區(qū)域。
2)Java虛擬機棧
Java Virtual Machine Stack
生命周期與線程相同,,描述的是java方法執(zhí)行的內(nèi)存模型。每個方法被執(zhí)行的時候都會創(chuàng)建一個棧幀。
3)本地方法棧
Native Method Stack
為虛擬機使用到的native方法服務(wù)。在Sun HotSpot中,把本地方法棧和虛擬機棧和二為一了。
4)方法區(qū)
Method Area
被所有線程共享的一塊內(nèi)存區(qū),存放一被虛擬機加載的類信息、常量、靜態(tài)變量、即時編譯器編譯后的代碼等數(shù)據(jù)。方法區(qū)和永久代本質(zhì)上并不等價,HotSpot只是用永久代實現(xiàn)方法區(qū)而已。
5)堆
Heap
被所有線程共享的一塊內(nèi)存區(qū),存放對象實例。
6)運行時常量池
Runtime Constant Pool
是方法區(qū)的一部分,用于存放編譯器生成的各種字面量和符號。例如:String類的intern()方法
7)直接內(nèi)存
Direct Memory
并不是虛擬機運行時數(shù)據(jù)區(qū)的一部分,它使用了Native函數(shù)庫直接分配堆外內(nèi)存。

1)程序計數(shù)器
Program Counter Register
是一小塊內(nèi)存空間,他的作用是當(dāng)前線程所執(zhí)行的行號指示器。此內(nèi)存區(qū)是唯一一個沒有規(guī)定OutOfMemoryError情況的區(qū)域。
2)Java虛擬機棧
Java Virtual Machine Stack
生命周期與線程相同,,描述的是java方法執(zhí)行的內(nèi)存模型。每個方法被執(zhí)行的時候都會創(chuàng)建一個棧幀。
3)本地方法棧
Native Method Stack
為虛擬機使用到的native方法服務(wù)。在Sun HotSpot中,把本地方法棧和虛擬機棧和二為一了。
4)方法區(qū)
Method Area
被所有線程共享的一塊內(nèi)存區(qū),存放一被虛擬機加載的類信息、常量、靜態(tài)變量、即時編譯器編譯后的代碼等數(shù)據(jù)。方法區(qū)和永久代本質(zhì)上并不等價,HotSpot只是用永久代實現(xiàn)方法區(qū)而已。
5)堆
Heap
被所有線程共享的一塊內(nèi)存區(qū),存放對象實例。
6)運行時常量池
Runtime Constant Pool
是方法區(qū)的一部分,用于存放編譯器生成的各種字面量和符號。例如:String類的intern()方法
7)直接內(nèi)存
Direct Memory
并不是虛擬機運行時數(shù)據(jù)區(qū)的一部分,它使用了Native函數(shù)庫直接分配堆外內(nèi)存。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
