《Dubbo 实现原理与源码解析 —— 精品合集》 《Netty 实现原理与源码解析 —— 精品合集》
《Spring 实现原理与源码解析 —— 精品合集》 《MyBatis 实现原理与源码解析 —— 精品合集》
《Spring MVC 实现原理与源码解析 —— 精品合集》 《数据库实体设计合集》
《Spring Boot 实现原理与源码解析 —— 精品合集》 《Java 面试题 + Java 学习指南》

摘要: 原创出处 网络 「网络」欢迎转载,保留摘要,谢谢!


🙂🙂🙂关注微信公众号:【芋道源码】有福利:

  1. RocketMQ / MyCAT / Sharding-JDBC 所有源码分析文章列表
  2. RocketMQ / MyCAT / Sharding-JDBC 中文注释源码 GitHub 地址
  3. 您对于源码的疑问每条留言将得到认真回复。甚至不知道如何读源码也可以请教噢
  4. 新的源码解析文章实时收到通知。每周更新一篇左右
  5. 认真的源码交流微信群。

前言:

  • 了解Java中的对象、变量等存放的内存区域十分重要
  • 本文将全面讲解Java虚拟机中的内存模型 & 分区,希望你们会喜欢

img

目录:

img

1. 内存模型 & 分区

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

    运行时数据区

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

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

img

  • 下面,我将详细介绍每个内存模型分区

2. Java 堆

  • 示意图

img

  • 简介

img

3. Java 虚拟机栈

  • 示意图

img

  • 简介

img

4. 本地方法栈

  • 示意图

img

  • 简介

    十分类似Java虚拟机栈,与Java虚拟机区别在于:服务对象,即Java虚拟机栈为执行 Java方法服务;本地方法栈为执行 Native方法服务

5. 方法区

  • 示意图

img

  • 简介

img

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

img

6. 程序计数器

  • 示意图

img

  • 简介

img

7. 额外知识:直接内存

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

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

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

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

img

文章目录
  1. 1. 1. 内存模型 & 分区
  2. 2. 2. Java 堆
  3. 3. 3. Java 虚拟机栈
  4. 4. 4. 本地方法栈
  5. 5. 5. 方法区
  6. 6. 6. 程序计数器
  7. 7. 7. 额外知识:直接内存