线程共享:堆、方法区
线程隔离:虚拟机栈、本地方法栈、程序计数器
程序计数器:一块较小的内存空间,执行的字节码的行号指示器
虚拟机栈:用于Java方法执行的线程内存模型,存储 局部变量表、操作数栈、动态链接、方法出口
局部变量表存储了编译期可知的各种基本数据类型(以局部变量槽Slot为单位,long 和 double 占两位,其余只占一个)+对象引用
如果线程请求的栈深度大于虚拟机所允许的深度,将抛出StackOverflowError异常;如果Java虚拟机栈容量可以动态扩展[插图],当栈扩展时无法申请到足够的内存会抛出OutOfMemoryError异常
本地方法栈:native
java堆:虚拟机管理的内存中最大的一块,用来存放对象实例
方法区:它用于存储已被虚拟机加载的类型信息、常量、静态变量、即时编译器编译后的代码缓存等数据
运行时常量池 用于存放编译期生成的各种字面量与符号引用 不过一般来说,除了保存Class文件中描述的符号引用外,还会把由符号引用翻译出来的直接引用也存储在运行时常量池中
直接内存:在JDK 1.4中新加入了NIO(New Input/Output)类,引入了一种基于通道(Channel)与缓冲区(Buffer)的I/O方式,它可以使用Native函数库直接分配堆外内存,然后通过一个存储在Java堆里面的DirectByteBuffer对象作为这块内存的引用进行操作。这样能在一些场景中显著提高性能,因为避免了在Java堆和Native堆中来回复制数据