专栏首页空帆船wJVM 内存结构

JVM 内存结构

Java 虚拟机在执行 Java 程序的过程中会把它管理的内存划分为若干个不同的数据区域。

这些区域中,一些是线程私有的,一些是线程共享的。

线程私有的:程序计数器、虚拟机栈、本地方法栈

线程共享的:堆、方法区、直接内存

1、程序计数器

一块较小的内存空间,用于标记当前线程所执行字节码的行号。

Java 虚拟机的多线程是通过线程轮流切换并分配处理器执行时间的方式实现,所以确定的时刻一个处理器只会执行一个线程中的指令。

为了线程切换后能恢复到正确的执行位置,每个线程都需要一个独立的程序计数器,用于记录线程所执行字节码指令的地址。

2、虚拟机栈

Java 虚拟机栈是由一个个帧栈组成。

每个方法执行时会创建一个栈帧,用于存储局部变量表、操作数栈、动态链接、方法出口等信息。

当方法调用时,栈帧入栈,方法结束时,栈帧出栈。

局部变量表的所需的内存空间在编译期间完成分配,运行时不会改变大小。

虚拟机栈定义了两种异常状况:StackOverFlowError 和 OutOfMemoryError 。

  • StackOverFlowError:线程请求的栈深度大于虚拟机所允许的深度。
  • OutOfMemoryError :大多数虚拟机都允许动态扩展虚拟机栈的大小,所以线程可以一直申请栈,直到内存不足时,抛出 OutOfMemoryError。

3、本地方法栈

本地方法栈为虚拟机使用到的 native 方法服务。

HotSpot 虚拟机直接把虚拟机栈与本地方法栈合二为一。与虚拟机栈一样,也会抛出 StackOverFlowError 和 OutOfMememoryError 异常。

4、堆

Java 堆是垃圾收集器管理的主要区域,也称为 GC 堆。所有实例和数组都在这里分配内存,也是线程共享的内存区域。

-Xms 设置最小值;-Xmx 设置最大值。

堆内存分配会另写一篇文章介绍。

5、方法区

与 Java 堆一样,也是线程共享的内存区域,用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译后的代码等数据。

在 HotSpot 虚拟机中,这块区域对应永久代,不易被回收。

运行时常量池:属于方法区一部分。用于存放编译期生成的常量和引用。

JDK 1.7 之后已经将运行时常量池从移出,在堆上开辟了一块区域存放运行时常量池。

6、直接内存

直接内存并不是虚拟机内存的一部分,也不是 Java 虚拟机规范中定义的内存区域。

jdk1.4 中新加入的 NIO,引入了通道与缓冲区的 IO 方式,它可以调用 Native 方法直接分配堆外内存,这个堆外内存就是本机内存,不会影响到堆内存的大小。

本文分享自微信公众号 - JaqenTalk(gh_a27e6529b76c)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-01-16

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • JVM 内存结构

    Java 虚拟机在执行 Java 程序的过程中会把它管理的内存划分为若干个不同的数据区域。

    用户3596197
  • Android 学习之路

    从事 Android 开发一周年了,作为一个非科班出身的程序员,一路走来其实挺不容易的。这里我想记录这一路的自学历程,算是对自己一个阶段的总结,也希望能给那些正...

    用户3596197
  • Java 反射基础

    最近在调研 Android 应用加固方案,涉及大量反射技术,因此趁这个机会总结下 Java 反射的一些知识。

    用户3596197
  • JVM 内存结构

    Java 虚拟机在执行 Java 程序的过程中会把它管理的内存划分为若干个不同的数据区域。

    用户3596197
  • JVM笔记【1】-- 运行时数据区

    C/C++每一个new操作都需要自己去delete/free,而java里面有虚拟机自动管理内存,不容易出现内存泄漏或者溢出的问题,但是不容易出现不代表不出现,...

    秦怀杂货店
  • OutOfMemoryError异常系列之虚拟机栈和本地方法栈溢出

    按照上一篇文章的分类,虚拟机栈与本地方法栈本应该分开讲,但是因为我用的虚拟机是Hotspot,虚拟机栈与本地方法栈为一个,所以,在此一起讲解。对于HotSpot...

    用户1257393
  • JVM的内存结构

    孙晨c
  • JVM运行时数据区域及GC

    方法区 (Method Area or Permanent Generation):

    哲洛不闹
  • BAT面试必问题系列:深入详解JVM 内存区域及内存溢出分析

    在JVM的管控下,Java程序员不再需要管理内存的分配与释放,这和在C和C++的世界是完全不一样的。所以,在JVM的帮助下,Java程序员很少会关注内存泄露和内...

    Java搬砖工人
  • JVM-1. Java运行时内存

    悠扬前奏

扫码关注云+社区

领取腾讯云代金券