程序計數(shù)器
當前線程所執(zhí)行的字節(jié)碼的行號指示器。
分支坑质、循環(huán)、跳轉(zhuǎn)、異常處理洪乍、線程恢復等基礎功能都依賴于它眯杏。
如果執(zhí)行的是Java方法,這個計數(shù)器記錄的是正在執(zhí)行的虛擬機字節(jié)碼指令的地址壳澳;如果執(zhí)行的是Native方法岂贩,這個計數(shù)器值則為空(Undefined)。
虛擬機棧
虛擬機棧描述的是Java方法執(zhí)行的內(nèi)存模型巷波,每個方法執(zhí)行時都會創(chuàng)建一個棧幀(Stack Frame)用于存儲局部變量表萎津、操作數(shù)棧、動態(tài)鏈接抹镊、方法出口等锉屈。
常說的棧就是指虛擬機棧
局部變量表存放編譯器可知的各種基本數(shù)據(jù)類型、對象引用(可能是引用指針或句柄)和returnAddress類型(指向了一條字節(jié)碼指令的地址)
當進入一個方法時垮耳,這個方法需要在棧幀中分配多大的局部變量空間時確定的颈渊,方法運行期間不會改變局部變量表的大小。
StackOverFlowError 線程請求的棧深度大于虛擬機允許的深度時拋出
OutOfMemoryError 如果虛擬機椫辗穑可以動態(tài)拓展俊嗽,如果拓展時無法申請到足夠的內(nèi)存,拋出
本地方法棧
本地方法棧作用與虛擬機棧類似铃彰,只是本地方法棧為虛擬機用到的Native方法服務绍豁,而虛擬機棧為Java方法服務。
拋出的異常和虛擬機棧相同
Java堆
Java堆牙捉,也被稱為GC堆(Garbage Collection Heap)竹揍,唯一目的就是存放對象實例。
從內(nèi)存回收角度邪铲,收集器多采用分代收集算法芬位,依此Java堆可以分為新生代和老年代;更細致點分為 Eden空間霜浴、From Survivor空間晶衷、To Survivor空間;
從內(nèi)存分配角度阴孟,線程共享的Java堆中可能劃分出多個線程私有的分配緩沖區(qū)TLAB(Thread Local Allocation Buffer)晌纫。
OutOfMemoryError 堆中內(nèi)存不足且無法拓展時拋出
方法區(qū)(私以為Class區(qū)更合適)
方法區(qū)用于存儲已被虛擬機加載的類信息、常量永丝、靜態(tài)常量锹漱、即時編譯器編譯后的代碼等。
方法區(qū)又被稱為“永久代”(permanent Gereration)慕嚷, 因為收集條件極為苛刻哥牍,所以垃圾收集行為在這個區(qū)域較少出現(xiàn)
內(nèi)存不足時拋出OutOfMemoryError
運行時常量池
運行時常量池 是方法區(qū)的一部分毕泌,常量池(Constant Pool Table)用于存放編譯器生成的各種字面值和符號引用,這部分內(nèi)容在類加載后進入方法區(qū)的運行時常量池中存放嗅辣。
一個重要特征是動態(tài)性撼泛,運行期間可能將新的常量放入池中,這個特性String類的intern()方法用的較多
直接內(nèi)存
直接內(nèi)存不屬于虛擬機運行時數(shù)據(jù)區(qū)也不是Java虛擬機規(guī)范中定義的內(nèi)存區(qū)域澡谭,不受Java堆的限制愿题。
通過NIO調(diào)用Native函數(shù)庫直接分配堆外內(nèi)存,然后通過一個存儲在Java堆中的DirectByteBuffer對象作為這塊內(nèi)存的引用進行操作蛙奖,提高了性能(避免了在Java堆和Native堆中來回復制數(shù)據(jù))潘酗。