图解 Java 内存模型

转自

1. 内存模型 & 分区

Java虚拟机在运行Java程序时,会管理着一块内存区域:运行时数据区

在运行时数据区里,会根据用途进行划分:

  1. Java虚拟机栈(栈区)
  2. 本地方法栈
  3. Java堆(堆区)
  4. 方法区
  5. 程序计数器

2. Java堆

备注:

  • Java堆是垃级收集器管理的主要区域,因此被称为:"GC堆";

  • 从内存回收的角度可分为:新生代&老年代

  • 新生代可细分:Eden 空间、From Survivor 空间、To Survivor 空间

  • 从内存分配的角度:多个线程私有的分配缓冲区

3. Java虚拟机栈

4. 本地方法栈

备注:

本地方法栈十分类似Java虚拟机栈

与Java虚拟机区别在于:服务对象,即:

  • Java虚拟机栈为执行 Java 方法服务;

  • 本地方法栈为执行 Native方法服务

5. 方法区

注:其内部包含一个运行时常量池,具体介绍如下:

6. 程序计数器

7. 额外知识:直接内存

  • 定义:NIO类(JDK1.4引入)中基于通道和缓冲区的I/O方式 通过使用Native函数库 直接分配 的堆外内存
  • 特点:不受堆大小限制

不属于虚拟机运行时数据区的一部分 & 不在堆中分配

  • 应用场景:适用于频繁调用的场景

通过一个 存储在Java堆中的DirectByteBuffer对象 作为这块内存的引用 进行操作,从而避免在 Java 堆和 Native堆之间来回复制数据,提高使用性能

  • 抛出的异常:OutOfMemoryError,即与其他内存区域的总和 大于 物理内存限制

8. 总结

本文全面讲解JVM中的内存模型 & 分区,总结如下