【java】JVM内存区域管理

JVM内存区域

文章目录

  • JVM内存区域
    • 运行时数据区域
    • 对象内存布局


运行时数据区域

运行时数据区域包括:虚拟机栈,方法区,堆,程序计数器,本地方法栈

  • 线程共享

    • 堆(对象实例、对象数组)

      从回收内存的角度,基于分代的思想,划分:

      新生代(1/3)
      	Eden(8)
      	survivor1(1)
      	survivor2(1)
      
      老年代(2/3)
      
    • 方法区(非堆) | 元空间(JDK8在本地内存实现)(存储类型信息、常量、静态变量、即时编译器编译的代码缓存等数据)

      • 运行时常量池:编译期生成的各种字面量和字符引用
  • 线程私有

    • 程序计数器(指向当前线程正在执行的字节码的指令的地址(行号))

    • 本地方法栈(当前线程运行native方法所需数据、指令、返回地址)

    • 虚拟机栈

      栈帧(方法):
      
          1.局部变量表(方法中定义的变量)
          
          2.操作数栈(值入栈出栈)
          
          3.动态链接(动态运行时,栈帧所属方法的符号引用转化为直接引用)
          
          4.返回地址(方法退出时,要回到最初方法被调用时的位置)		
          
      

【java】JVM内存区域管理_第1张图片

对象内存布局

对象在堆内存存储布局分为三块:对象头、实例数据和对齐填充(占位符)

对象头

  • 自身运行时数据,包括hashcodeGC分代年龄、锁状态标志、线程持有的锁、偏向线程id、偏向时间戳
  • 类型指针,对象指向它的类型元数据的指针,虚拟机通过这个指针确认对象属于哪个类的实例

32位虚拟机中:对象头 = 25位对象hashcode + 4位分代年龄 + 2位锁标志 + 1位固定0

你可能感兴趣的:(java,jvm,java,开发语言)