jvm之运行时数据区

Jvm运行时内存模型:

jvm运行时数据区分为共享与非共享两类。

  • 共享:堆、方法区
  • 不共享:虚拟机栈、本地方法栈、程序计数器

jvm运行时数据区

程序计数器

用来存放字节码指令,这个区域不会出现oom。

用来存放对象实例的。这个地方是垃圾回收的主要区域。
堆内存的划分比较特殊。主要是有两种:一种是整个区域划分为年轻代、老年代、幸存区等。还有一种:将内存划分为若干个小区域。每个区域根据自己的需求可以扮演不同的角色,jdk8只有g1是这么干的,好处就是,只需要对需要进行回收的小区域回收即可。
虚拟机参数:-xmx,-xms。一般指定两个数值相同,防止内存抖动。

虚拟机栈

方法执行的线程内存模型。每一个方法执行都会创建一个栈帧。方法执行完的过程对应一个栈帧的入栈与出栈。
栈帧:包含局部变量表、操作数栈、动态连接、方法出口等信息。
局部变量表:包含多个变量槽、用来存储基本数据、返回地址、与引用类型。其中64位的类型占2个,其他的占一个。并且在运行时局部变量表大小不会变。
本区域会出现oom:当请求的栈深度>所允许的深度时。
在这里插入图片描述

本地方法栈

与虚拟机栈差不多,不过这里的方法指的是native方法,就是本地方法。

方法区

用来存放已被虚拟机加载的类型信息、常量、静态变量、即时编译器编译后的代码缓存等。

运行时常量池

为方法区的一部分。用来存放常量池表(类文件结构之一),编译器生成的符号引用以及字面量。是动态的,不一定只有编译期产生。如string.intern。当常量池无法申请到内存时也会出现oom。

直接内存

并不是运行时数据区的一部分,但是会用到 , 如nio中channel与buffer可以通过native方法直接分配堆外内存。如果不考虑直接内存会导致分配的总内存大于物理内存从而导致oom。

本文中的图片都是摘自《深入理解Java虚拟机_JVM高级特性与最佳实践_第3版》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值