文章轉載自 於 微信公衆號Java引導者,非本人公衆號
前言:
-
瞭解
Java
中的對象、變量等存放的內存區域十分重要 -
本文將全面講解
Java
虛擬機中的內存模型 & 分區,希望你們會喜歡 -
更多文字解釋,概念理解請點擊上一篇:https://blog.csdn.net/Soinice/article/details/98038991
內存模型 & 分區
-
Java
虛擬機在運行Java
程序時,會管理着一塊內存區域:運行時數據區
-
在運行時數據區裏,會根據用途進行劃分:
-
Java
虛擬機棧(棧區) -
本地方法棧
-
Java
堆(堆區) -
方法區
-
程序計數器
-
下面,我將詳細介紹每個內存模型分區:
Java堆:
-
示意圖
-
簡介
Java虛擬機棧
-
示意圖
-
簡介
本地方法棧
-
示意圖
簡介
十分類似Java
虛擬機棧,與Java虛擬機區別在於:服務對象,即Java虛擬機棧爲執行 Java
方法服務;本地方法棧爲執行 Native
方法服務
方法區
-
示意圖
簡介
-
注
其內部包含一個運行時常量池,具體介紹如下:
程序計數器
-
示意圖
-
簡介
額外知識:直接內存
-
定義:
NIO
類(JDK
1.4引入)中基於通道和緩衝區的I/O
方式 通過使用Native
函數庫 直接分配 的堆外內存
-
特點:不受堆大小限制
-
應用場景:適用於頻繁調用的場景
通過一個 存儲在
Java
堆中的DirectByteBuffer
對象 作爲這塊內存的引用 進行操作,從而避免在Java
堆和Native
堆之間來回複製數據,提高使用性能
-
拋出的異常:
OutOfMemoryError
,即與其他內存區域的總和 大於 物理內存限制 -
本文全面講解JVM中的內存模型 & 分區,總結如下