JVM内存区域结构:一计两栈一堆一区

云计算 虚拟化
Java虚拟机都会同步创建一个栈(StackFrame)用于存储局部变量表、操作数栈、 动态连接、方法出口等信息。每一个方法被调用直至执行完毕的过程,就对应着一个栈帧在虚拟机栈中从入栈到出栈的过程。

[[320318]]

1程序计数器

  • 一块较小的内存空间。
  • 当前线程所执行的字节码的行号指示器。

2虚拟机栈

描述的是Java方法执行的线程内存模型:每个方法被执行的时候,Java虚拟机都会同步创建一个栈(StackFrame)用于存储局部变量表、操作数栈、 动态连接、方法出口等信息。每一个方法被调用直至执行完毕的过程,就对应着一个栈帧在虚拟机栈中从入栈到出栈的过程。

局部变量表(存放)

  • 基本数据类型
  • 对象引用
  • returnAddress类型(指向了一条字节码指令的地址)

异常

StackOverflowError:线程请求的栈深度大于虚拟机所允许的深度

OutOfMemoryError:栈扩展时无法申请到足够的内存

3本地方法栈

虚拟机使用到的本地(Native)方法服务。

4Java堆回收内存的角度

新生代、老年代、永久代、Eden空间、From Survivor空间、To Survivor空间。

分配内存的角度

所有线程共享的Java堆中可以划分出多个线程私有的分配缓冲区(Thread Local Allocation Buffer,TLAB)。

异常

OutOfMemoryError:没有内存完成实例分配, 并且堆也无法再扩展时

5方法区

  • 各个线程共享的内存区域
  • 用于存储已被虚拟机加载的类型信息、常量、静态变量、即时编译器编译后的代码缓存等数据
  • JDK8将永久代废弃,相应的用元空间MetaSpace

异常

OutOfMemoryError:无法满足新的内存分配需求时

6运行时常量池

  • 方法区的一部分
  • 用于存放编译期生成的各种字面量与符号引用, 这部分内容将在类加载后存放到方法区的运行时常量池中

异常

OutOfMemoryError:当常量池无法再申请到内存

7直接内存

不是虚拟机运行时数据区的一部分

本机直接内存的分配不会受到Java堆大小的限制 

 

总结:

 

JVM内存区域结构包含:程序计数器、虚拟机栈、本地方法栈、Java堆、方法区。可以简记为:一计两栈一堆一区,方便记忆。

方法区包含运行时常量池,还有直接内存(NIO更常见)。

需要了解到每个区域是主要作用是什么,这样才能更加牢固的掌握。

 

责任编辑:武晓燕 来源: 搬运工来架构
相关推荐

2023-12-26 12:37:08

内存模型堆排序

2024-11-26 08:31:36

2020-07-12 15:29:58

Windows工具微软

2016-09-22 16:09:36

大数据PB级NoSQL

2023-07-31 07:48:43

Java内存虚拟机

2019-12-12 11:19:33

JVM内存线程

2010-09-25 12:54:24

JVM内存

2013-08-14 17:47:48

企业2.0企业社交网络

2011-11-23 10:01:43

虚拟化软件许可IIS

2023-11-01 08:07:42

.NETC#

2013-03-29 11:09:17

JVM内存

2020-08-27 21:36:50

JVM内存泄漏

2013-04-08 10:49:53

当我们变成一堆数字大数据时代

2023-05-31 14:08:44

视觉功能信号想象

2023-11-06 07:21:13

内存结构Jvm

2010-09-27 08:38:49

JVM堆JVM栈

2023-11-05 12:05:35

JVM内存

2010-03-31 14:20:23

Oracle内存结构

2020-03-02 08:33:35

高质量可维护代码

2017-06-03 15:22:26

windowsInsider微软
点赞
收藏

51CTO技术栈公众号