Java JVM 之运行时内存区域

Java JVM 之运行时内存区域

一直以来都不明白Java JVM 的原理,都只是当成黑匣子来用,也没有深入的去理解。最近需要找实习,所以需要深入的了解JVM的内部机制。

以下这张图是做的相关的总结。
在JVM的运行时数据区中,主要包括5个部分:

  1. 方法区
  2. 虚拟机栈
  3. 本地方法栈
  4. 程序计数器

可以直接看图,图片很清晰了。
运行时数据区域

简单说明:

程序计数器

就是程序当前执行到的位置(地址),程序的分支、循环、跳转、异常处理、线程恢复等基础的功能都依赖于计数器,且计数器是线程私有的,不同的线程之间的计数器互不影响,独立存储,且这个部分是Java虚拟机规范中没有规定任何OutOfMemoryError的区域
需要特别注意的是:如果执行的Native方法,计数器的数值为空。

Java 虚拟机栈

图片中所说的,long、double占用两个空间,是在64位的情况下的。

本地方法栈

虚拟机栈是为执行Java方法服务的,而本地方法栈是为了Native方法服务的。且对本地方法栈中使用的语言、方式与数据结构没有强制规定,所以可以自由实现。

Java堆

所有线程共享的一块内存区域,在虚拟机启动时创建。这个内存区域的唯一目的就是用来存放对象实例的,而在旧版本的Java虚拟机实现中几乎所有的对象实例和数据都要在这个区域上分配。Java堆是垃圾收集器管理的主要区域,基本上都采用分代收集算法,所以还可以细分为新生代和老年代。

方法区

同样是线程共享的区域。

猜你喜欢

转载自blog.csdn.net/qq_34911465/article/details/79465044