目录
- 内存模型与分区
- Java堆
- Java虚拟机栈
- 本地方法栈
- 方法区
- 程序计数器
- 延伸知识:直接内存
- 总结
一、内存模型 & 分区
Java虚拟机在运行Java程序时,会管理着一块内存区域:运行时数据区
在运行时数据区里,会根据用途进行划分:
- Java虚拟机栈(栈区)
- 本地方法栈
- Java堆(堆区)
- 方法区
- 程序计数器
下面,我将详细介绍每个内存模型分区
1、Java堆
- 示意图
- 简介
2、Java虚拟机栈
- 示意图
- 简介
3、本地方法栈
- 示意图
- 简介
十分类似Java虚拟机栈,与Java虚拟机区别在于:服务对象,即
Java虚拟机栈为执行 Java 方法服务;本地方法栈为执行 Native方法服务
4、方法区
- 示意图
- 简介
- 注
其内部包含一个运行时常量池,具体介绍如下:
5、程序计数器
- 示意图
- 简介
二、延伸知识:直接内存
- 定义:NIO类(JDK1.4引入)中基于通道和缓冲区的I/O方式 通过使用Native函数库 直接分配 的堆外内存
- 特点:不受堆大小限制
不属于虚拟机运行时数据区的一部分 & 不在堆中分配
- 应用场景:适用于频繁调用的场景
通过一个 存储在Java堆中的DirectByteBuffer对象 作为这块内存的引用 进行操作,从而避免在 Java 堆和
Native堆之间来回复制数据,提高使用性能
- 抛出的异常:OutOfMemoryError,即与其他内存区域的总和 大于 物理内存限制
总结
本文全面讲解JVM中的内存模型 & 分区,总结如下: