前言
- 了解Java中的對象、變量等存放的內(nèi)存區(qū)域十分重要
- 本文將全面講解Java虛擬機(jī)中的內(nèi)存模型 & 分區(qū),希望你們會喜歡
目錄
1、內(nèi)存模型 & 分區(qū)Java虛擬機(jī)在運(yùn)行Java程序時,會管理著一塊內(nèi)存區(qū)域:運(yùn)行時數(shù)據(jù)區(qū)在運(yùn)行時數(shù)據(jù)區(qū)里,會根據(jù)用途進(jìn)行劃分:
- Java虛擬機(jī)棧(棧區(qū))
- 本地方法棧
- Java堆(堆區(qū))
- 方法區(qū)
- 程序計(jì)數(shù)器
下面,我將詳細(xì)介紹每個內(nèi)存模型分區(qū)
2、Java堆
簡介
3、Java虛擬機(jī)棧
簡介
4、本地方法棧
簡介:十分類似Java虛擬機(jī)棧,與Java虛擬機(jī)區(qū)別在于:服務(wù)對象,即Java虛擬機(jī)棧為執(zhí)行 Java 方法服務(wù);本地方法棧為執(zhí)行 Native方法服務(wù)
給大家推薦一份《JVM進(jìn)階學(xué)習(xí)筆記》,深入了解JVM參數(shù)、常用命令、內(nèi)存、GC、JVM性能優(yōu)化指南。以及其他常見問題,??點(diǎn)擊此處即可免費(fèi)領(lǐng)取???。。?/strong>
5、方法區(qū)
簡介
注:其內(nèi)部包含一個運(yùn)行時常量池,具體介紹如下:
6、程序計(jì)數(shù)器
簡介
7、額外知識:直接內(nèi)存
- 定義:NIO類(JDK1.4引入)中基于通道和緩沖區(qū)的I/O方式 通過使用Native函數(shù)庫 直接分配 的堆外內(nèi)存
- 特點(diǎn):不受堆大小限制
不屬于虛擬機(jī)運(yùn)行時數(shù)據(jù)區(qū)的一部分 & 不在堆中分配
- 應(yīng)用場景:適用于頻繁調(diào)用的場景
通過一個 存儲在Java堆中的DirectByteBuffer對象 作為這塊內(nèi)存的引用 進(jìn)行操作,從而避免在 Java 堆和 Native堆之間來回復(fù)制數(shù)據(jù),提高使用性能
- 拋出的異常:OutOfMemoryError,即與其他內(nèi)存區(qū)域的總和 大于 物理內(nèi)存限制
8、總結(jié)
本文全面講解JVM中的內(nèi)存模型 & 分區(qū),總結(jié)如下