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

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

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