JVM运行时数据区(下篇)

 紧接上篇:JVM运行时数据区(上篇)-CSDN博客 

  • 一般Java程序中堆内存是空间最大的一块内存区域。创建出来的对象都存在于堆上。
  • 栈上的局部变量表中,可以存放堆上对象的引用。静态变量也可以存放堆对象的引用,通过静态变量就可以实现对象在线程之间共享。
  • 字符串常量池,存储字符串的常量。

JVM运行时数据区(下篇)_第1张图片

  • 堆空间有三个需要关注的值,used total max。
  • used指的是当前已使用的堆内存,total是java虚拟机已经分配的可用堆内存,max是java虚拟机可以分配的最大堆内存。
  • 当total达到max时说明可分配内容已满,注意此时并不代表OOM!

JVM运行时数据区(下篇)_第2张图片

方法区

方法区是Java虚拟机规范中提出来的一个虚拟机概念,在HotSpot不同版本中会用永久代或者元空间来实现。方法区主要存放的是基础信息,包含:

  • 每一个加载的类的元信息(基础信息)。
  • 运行时常量池,保存了字节码文件中的常量池内容,避免常量内容重复创建减少内存开销。
ps:jdk1.8

JVM运行时数据区(下篇)_第3张图片

总结

JVM运行时数据区(下篇)_第4张图片

ps:jdk8

运行时数据区指的是JVM所管理的内存区域,其中分成两大类:

  • 线程共享 – 方法区、堆
    • 方法区:存放每一个加载的类的元信息、运行时常量池、字符串常量池。
    • 堆:存放创建出来的对象。
  • 线程不共享 – 本地方法栈、虚拟机栈、程序计数器
    • 本地方法栈和虚拟机栈都存放了线程中执行方法时需要使用的基础数据。
    • 程序计数器存放了当前线程执行的字节码指令在内存中的地址。
    • 直接内存主要是NIO使用,由操作系统直接管理,不属于JVM内存。

你可能感兴趣的:(jvm)