原创

JVM:图文详解Java虚拟机的内存结构

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://carsonho.blog.csdn.net/article/details/101667672

前言

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

在接下来的日子,我会推出一系列讲解JVM的文章,具体如下;感兴趣可持续关注 Carson_Ho的CSDN博客哦

示意图


目录

示意图


1. 内存模型 & 分区

  • Java虚拟机在运行Java程序时,会管理着一块内存区域:运行时数据区
  • 在运行时数据区里,会根据用途进行划分:
    1. Java虚拟机栈(栈区)
    2. 本地方法栈
    3. Java堆(堆区)
    4. 方法区
    5. 程序计数器

示意图

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

2. Java堆

  • 示意图
    示意图

  • 简介

示意图

关于垃圾回收的讲解会在接下来推出的文章里讲解


3. Java虚拟机栈

  • 示意图
    示意图

  • 简介

示意图


4. 本地方法栈

  • 示意图

示意图

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

5. 方法区

  • 示意图
    示意图

  • 简介

示意图


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

示意图


6. 程序计数器

  • 示意图

示意图

  • 简介

示意图


7. 额外知识:直接内存

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

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

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

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

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

8. 总结

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

示意图

  • 在接下来的日子,我会推出一系列讲解JVM的文章,具体如下;感兴趣的同学可以继续关注本人运营CSDN博客哦:https://blog.csdn.net/carson_ho

示意图


请帮顶 / 评论点赞!因为你的鼓励是我写作的最大动力!

文章最后发布于: 2019-09-29 07:36:57
展开阅读全文
2 个人打赏 ljk126wy ruming5582
私信求帮助

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 编程工作室 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览