JVM之Java虚拟机图文详解

文章转载自 于 微信公众号Java引导者,非本人公众号

前言:                                                            

内存模型 & 分区

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

    运行时数据区

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

    1. Java虚拟机栈(栈区)

    2. 本地方法栈

    3. Java堆(堆区)

    4. 方法区

    5. 程序计数器

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

Java堆:

  • 示意图

  • 简介

 Java虚拟机栈

  • 示意图

  • 简介

 本地方法栈

  • 示意图

简介

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

方法区

  • 示意图

简介

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

 程序计数器

  • 示意图

  • 简介

 额外知识:直接内存

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

  • 特点:不受堆大小限制

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

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

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

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

发布了178 篇原创文章 · 获赞 132 · 访问量 13万+

猜你喜欢

转载自blog.csdn.net/Soinice/article/details/102604235
今日推荐