JVM内存结构
2018-03-17 本文已影响6人
FreDdy_GY
-
程序计数器(Program Counter Register,线程私有)
当前线程所执行的字节码的行号指示器,每个线程都拥有独立的程序计数器,选取下一条指令、在线程切换时保存程序执行的进度都依赖程序计数器。是JVM中唯一没有规定任何OOM情况的区域。 -
Java虚拟机栈(Java Virtual Machine Stacks,线程私有)
Java方法执行时的内存模型,每个方法在执行时都会创建一个栈帧,栈帧中用于存储局部变量表、操作数栈、动态链接、方法出口等信息。我们粗糙定义JVM内存模型时有栈和堆的概念,Java虚拟机栈就是那个栈。 -
本地方法栈(Native Method Stack,线程私有)
作用与Java虚拟机栈十分类似,区别是:Java虚拟机栈为Java方法服务,而本地方法栈为native方法服务。有的虚拟机甚至会把两个栈合为一个。 -
Java堆(Java Heap,共享区域)
用于存放对象实例,几乎所有的对象实例都在这里分配内存,是垃圾收集器管理的主要区域。 -
方法区(Method Area,共享区域)
用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。所谓的“永久代”,GC回收要求非常严格。 -
运行时常量池(Runtime Constant Pool)
方法区的一部分,用于存放编译期生成的各种字面量和符号引用,具有动态性,运行期间也可以将新的常量放入池中,比如String类的intern()方法。 -
直接内存(Direct Memory)
并不是虚拟机运行时数据区的一部分,也不是Java虚拟机规范中定义的内存区域。是由native函数库直接分配的堆外内存,不会受到Java堆大小的限制,但还是会收到本机总内存大小的限制。