JVM内存空间

  1. 虚拟机栈:Stack Frame 栈帧(涉及方法执行时的入栈,出栈,局部变量表等);每个方法执行,都会创建一个栈帧,伴随着方法从创建到执行完成。用于存储局部变量表,操作数栈,动态链接和方法出口等。
  2. 程序计数器(Program Counter)(描述执行字节码执行顺序,先执行什么,下一条执行什么):保存当前线程执行的字节码位置,每个线程工作时都有独立的计数器。只为执行java方法服务,当执行Native方法时,程序计数器为空。
    程序计数器是一块比较小的内存空间,它可以看作是当前线程所执行的字节码的行号指示器。
    程序计数器处于线程独占区。此区域是唯一一个在java虚拟机规范中没有规定任何OutOfMemoryError的情况的区域;
    如果线程执行的是java方法,这个计数器记录的是正在执行的虚拟机字节码指令的地址;如果正在执行的是native方法,这个计数器值为undefined;
  3. 本地方法栈:主要用于执行本地方法
  4. 堆(Heap)(是线程共享的):JVM管理的最大一块内存空间。创建的对象位于堆上;对象不能直接使用或操作,通过引用来操作对象,而引用位于虚拟机栈上;
  5. 引用指向堆中的对象,堆中对象数据包含两个部分:1本身的实例数据,如成员变量等;2元数据,如所属类相关的信息,常量,静态变量;(元数据又存在于堆中一个单独区域:方法区。从JDK1.8开始就无永久代了,使用元空间meta space代替,元空间并不在虚拟机中,而是使用本地内存);方法区是JVM 的规范,元空间(永久代)(PermGen space)是HotSpot对这种规范的实现。
  6. 运行时常量池:方法区的一部分;
  7. 直接内存(Direct Memory):不由JVM管辖,由jvm申请,由操作系统管辖。
  8. 注:JVM内存空间与JMM(Java内存模型)是两个不同的概念。

String s1 = “abc”;// 在方法区中的运行时常量池中

String s2 = “abc”;

System.out.println(s1 == s2);//输出 : true

String s3  = new String(“abc”);//在堆内存中

System.out.println(s1 == s3);//输出:false

System.out.println(s1 == s3.intern);//输出:true //将s3转化到了运行时常量池中。

你可能感兴趣的:(JVM)