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