图解Java内存区域及内存溢出异常
圖解 Java 內(nèi)存區(qū)域及內(nèi)存溢出異常
在閱讀 《深入理解Java虛擬機:JVM高級特性與最佳實踐(第2版)?》后,為了加深對 Java 內(nèi)存區(qū)域的印象及理解,特意做成了思維導(dǎo)圖。
名詞解釋
線程共享數(shù)據(jù)區(qū)域
- 直接內(nèi)存
并不是虛擬機運行時數(shù)據(jù)區(qū)的一部分,也不是 Java 虛擬機規(guī)范中定義的內(nèi)存區(qū)。NIO 中使用 Native 函數(shù)直接分配堆外內(nèi)存
- 方法區(qū) Method Area
用于存放已被虛擬機加載的類信息、常量、靜態(tài)變量、JIT 編譯后的代碼等
也稱作 永久代,在這塊容易遇到 OOM 問題
- 堆 Heap
Java 堆是被所有線程共享的一塊內(nèi)存區(qū)域,在虛擬機啟動時創(chuàng)建。
目的:存放對象實例,幾乎所有的對象實例都在堆中分配。
GC 也主要發(fā)生在這里,所以也稱 GC 堆
- 運行時常量池
在運行時期能動態(tài)地將常量放入常量池中,例如 String.intern() 方法
線程隔離數(shù)據(jù)區(qū)域
- 虛擬機棧 VM Stack
描述 Java 方法執(zhí)行的內(nèi)存模型,為虛擬機運行 Java 提供服務(wù):
每個方法在執(zhí)行的時候都會創(chuàng)建一個棧幀(Stack Frame),用來存放局部變量表、操作數(shù)棧、動態(tài)鏈接、方法出口等信息。
每一個方法的調(diào)用到執(zhí)行完成的過程,就對應(yīng)著一個棧幀在虛擬機棧中入棧到出棧的過程。
- 局部變量表
即常說的 堆棧的棧
存放編譯可知的各種基本數(shù)據(jù)類型、對象引用、returnAddress類型
- 程序計數(shù)器 PCR
每條線程都有一個獨立的程序計數(shù)器,以便線程切換后能回到正確的位置不存在任何 OOM
- 本地方法棧 Native Method Stack
為本地方法 Native 提供服務(wù)
Note
該圖中的方法區(qū),也稱為永久代,在 Jdk 1.8 中,已經(jīng)不存在【永久代】了,改為【本地內(nèi)存】來實現(xiàn)方法區(qū)。
如果有寫錯的,歡迎留言指正。
轉(zhuǎn)載于:https://www.cnblogs.com/mintar/p/7221842.html
總結(jié)
以上是生活随笔為你收集整理的图解Java内存区域及内存溢出异常的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第12天续,CSS基础
- 下一篇: 【高斯消元】兼 【期望dp】例题