(一)总体架构图
(二)简介
- 程序计数器:当前线程执行的字节码的行号指示器。线程私有。
- java虚拟机栈:线程私有。虚拟机栈描述的是虚拟机执行Java方法执行的内存模型:每个方法被执行的时会同时创建一个栈帧(Stack Frame ①)用于存储局部变量表、操作栈、动态链接、方法出口等信息。
- 局部变量表:存放编译期可知的基本数据类型(boolean、byte、char、short、int、float、long、double)、对象引用reference 类型
- 本地方法栈:线程私有。描述的是虚拟机使用到的Native方法服务。
- Java堆:所有线程共享的。虚拟机启动时创建。
- 目的:存放对象实例,几乎所有的对象实例都在这里分配内存。
- Java堆是垃圾收集器管理的主要区域。也称GC堆
- 收集器基本都采用分代收集算法。Java堆可分为新生代和老年代。
- 方法区
- 所有线程共享。
- 用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据
- 运行时常量池
- 是方法区的一部分。Class 文件中除了有类的版本、字段、方法、接口等描述等信息外,还有一项信息是常量池(Constant PoolTable),用于存放编译期生成的各种字面量和符号引用,这部分内容将在类加载后存放到方法区的运行时常量池中。
- 直接内存:NIO可以使用Native函数库直接分配堆外内存,然后通过一个存储在Java 堆里面的DirectByteBuffer 对象作为这块内存的引用进行操作。这样能在一些场景中显著提高性能,因为避免了在Java 堆和Native 堆中来回复制数据。