您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關JVM運行時的數據區域,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
首先看圖:
1.程序計數器(PC)
是線程獨享的。是一塊較小的內存,是當前線程所執行的字節碼的行號指示器,是Java虛擬機規范中唯一沒有被規定OOM(OutOfMemoryError)的區域。
2.Java虛擬機棧
是線程獨享的。生命周期和線程相同。是Java方法執行的內存模型。執行每個方法都會創建一個棧幀,用于存儲局部變量和操作數(對象引用)。局部變量所需要的內存空間大小在編譯期間完成分配。所以棧幀的大小是不會改變的。
存在兩種異常情況:
1)若線程請求深度大于棧的深度,會拋出StackOverFlowError。
2)若棧在動態擴展的時候無法請求足夠的內存,會拋出OOM。
3.堆
Java堆是所有線程共享的。是虛擬機啟動的時候創建的。存放的是對象的實例和數組。所占內存最大。分為新生代(Young區)、老年代(Old區)。新生代又分為Eden區、Servior區。Servior區又分為From space區和To space區。Eden區和Servior區的內存比例為8:1。當擴展內存大于可用內存的時候,會拋出OOM。
4.本地方法棧
本地方法棧是線程獨享的。與Java虛擬機棧類似,但不是為Java方法(字節碼)服務,而是為本地非Java方法服務。也會拋出StackOverFlowError和OOM。
5.方法區
方法區是所有線程共享的。用于存儲已經被虛擬機加載的類信息、常量、靜態變量等數據,又稱為非堆(Non-Heap)。方法區又稱為“永久代”,GC很少在這個區域進行,但不代表不會回收。這個區域回收目標主要是針對常量池的回收和對類型的卸載。當內存申請大于實際可用內存時,會拋出OOM。
看完上述內容,你們對JVM運行時的數據區域介紹有進一步的了解嗎?如果還想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。