JDK 1.8 内存结构简介

JDK 1.8 内存结构


程序计数器

《深入理解java虚拟机》

记录当前线程执行的字节码行号。

① 线程私有。

② 如果执行的是native方法,值为null。

③ 此区域是JVM规范中唯一一个不存在OOM(OutOfMemory)的区域。

虚拟机栈

每一个线程执行时,都对应有一个虚拟机栈,生命周期与线程相同。一个虚拟机栈有一个一个的栈帧组成,每个java方法被调用时都会创建一个栈帧,然后入栈,方法结束后出栈。一个栈帧由局部变量表,操作数栈,动态链接和方法出口信息组成。

如果方法中出现递归调用死循环,或者栈帧大小超过虚拟机栈限制都会抛出StackOverflowError;

本地方法栈

功能与虚拟机栈差不多,只不过本地方法栈是虚拟机在调用native方法时使用。

堆是JVM占用比例最大的一块区域,用来存放对象实例。现代JVM大多将堆分为老年代和新生代。老年代与新生代比例为2:1。新生代分为一个Eden和两个Survivor区域,比例为8:1:1。

JDK1.7之后,运行时常量池从方法区中移入到堆中,存放一些符号引用。

​ Class对象和static成员变量,两者都位于堆(Heap),且static 成员变量位于 Class对象内。(在jdk1.7及以前 static成员变量是在方法区中,1.8改名元空间)

元数据区

在JDK1.7的时候,有一个JVM内存区域中有一块方法区,主要存放虚拟机加载的类信息,静态变量,常量等。

JDK1.8时,移除了方法区的概念,用一个元数据区代替。元数据区存放的东西和方法区大致相同(没有静态变量),不过元数据区移动到本地内存中。本地内存,又称堆外内存(Direct Memory),就是指机器内存中不是JVM管理的那部分内存,由操作系统管理。元数据区移动到本地内存以后,可以避免虚拟机加载类过多而引发的内存溢出:java.lang.OutOfMemoryError: PermGen,但是同样不能无限扩展。

常量池

    1. class文件常量池(静态常量池): 存储区域是在堆中,编译时产生对应的class文件,主要包含字面量和符号引用
    1. 运行时常量池: 存在与本地内存的元空间中,JVM运行时,在类加载完成后,将每个class常量池中的符号引用转换为直接引用,与全量池中保持一致
    1. 字符串常量池: 类在加载完成,经过验证,准备之后在堆中生成字符串对象实例,然后将该字符串对象实例的引用只存储到sting pool中,string pool是一个StringTable类,是哈希表结果,里面存储的是字符串引用,具体的实例对象存储在堆中,这个stringtable表在每个hotspot中的实例只有一份,被所有类共享。
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值