運行時數據區域 java
Java虛擬機在Java程序執行過程當中會把它所管理的內存劃分爲若干個數據區域,有的區域隨着虛擬機進程的啓動而存在,有的區域依賴用戶線程的啓動和結束而創建和銷燬。 算法
RUNTIME DATA AREAS SHARED AMONG ALL THEADS:由全部線程共享的數據區 app
THREAD SPECIFIC RUNTIME DATA AREAS:線程隔離的數據區 jvm
a,程序計數器(PROGRAM COUNTER REGISTER):是一塊較小的內存空間,他的做用能夠看作事當前線程所執行的字節碼的行號指示器。字節碼解釋器工做時就是經過改變這個計數器的值來選 取下一條須要執行的字節碼指令,分支,循環,跳轉,異常處理,線程回覆等基礎功能都須要依賴這個程序計數器來完成。各個線程間的計數器互不影響,獨立存 儲。 wordpress
b,Java虛擬機棧(JAVA STACK):也是線程私有的,每一個方法被執行的時候都會同時建立一個棧幀用於存儲局部變量表,操做棧,動態連接,方法出口燈信息。每一個方法被調用直至執 行完成的過程,就對應着一個棧幀在虛擬機棧中從入棧到出棧的過程。在java虛擬機規範中,對這個區域規定了兩種異常情況:若是線程請求的棧深度大於虛擬 機所容許的深度,將會拋出StackOverflowError異常;若是虛擬機棧擴展時沒法申請到足夠的內存時會拋出OutOfMemoryError 異常。 線程
c,本地方法棧(NATIVE METHOD STACK):和虛擬機棧發揮的做用類似,區別不過是虛擬機站爲虛擬機執行java方法服務,而本地方法棧則是爲虛擬機使用到的Native方法服務。 翻譯
d,Java堆(HEAP):java虛擬機中所普遍利用的內存中最大的一塊,被全部線程共享的一塊內存區域,在虛擬機啓動時建立。此內存區域用於存放 對象實例。如今收集器基本上都是採用分代收集算法,分爲:新生代和年老代;在細緻一點有Eden空間,From Survivor空間,To Survivor空間等。 對象
e,方法區(METHOD AREA):各個線程共享的存儲區域,用於存儲已被虛擬機加載的類信息,常量,靜態方法,即時編譯器編譯後的代碼等數據。也就是所說的永久代(Permanent Generation)。 進程
f,運行時常量池:Java虛擬機沒有作任何細節的要求,不一樣的提供商實現的虛擬機能夠按照本身的須要來實現這個內存區域。通常來講,除了保存Class文件中描述的符號引用外,還會把翻譯出來的直接引用也存儲在運行時常量池中。 內存