JVM--运行时数据区域

程序计数器:
一块较小的内存空间,当前线程所执行的字节码行号指示器。
字节码解析器工作时就是通过改变这个计数器来选取下一条需要执行的字节码指令。
Java虚拟机的多线程是通过线程轮流切换并分配处理器执行时间的方式来实现的。
在任何一个确定的时刻,一个处理器(对于多核处理器来说是一个内核)只会执行一条线程中的指令。
每条线程都需要一个独立的程序计数器(线程私有的内存)。
此内存区域是唯一一个在Java虚拟机规范中没有规定任何OutOfMemoryError情况的区域。

Java虚拟机栈:
线程私有,为虚拟机执行Java方法服务。
描述Java方法执行的内存模型。
每个方法执行的时候都会同时创建一个栈帧用于存储局部变量表,操作栈,动态链接,方法出口等信息。
局部变量表存放了编译期可知的各种基本数据类型,对象引用和 returnAddress 类型。

本地方法栈:
为虚拟机使用到的 Native 方法服务。

Java堆:
所有线程共享的一块内存区域,存放对象实例。
Java堆中可以细分为 新生代、老生代。
物理空间不连续,逻辑上连续。

方法区:
各个线程共享的内存区域,用于存储已被虚拟机加载的类信息,常量,静态常量,即时编译器编译后的代码等数据。
堆的一个逻辑部分。

运行时常量池:
方法区 的一部分。
存放编译期生成的各种字面量和符号引用(类加载后)。

直接内存:
不是虚拟机运行时数据区的一部分。
NIO:使用Native函数库直接分配堆外内存,通过存储在Java堆中的DirectByteBuffer对象作为这块内存的引用进行操作。
原文地址:https://www.cnblogs.com/jsersudo/p/11359418.html