JVM运行时数据区内存分布:
1 程序计数器:
很小的内存,记录当前线程所执行的字节码的行号指示器,字节码的解释器根据计数器的数值来确定下一条执行的字节码指令,逻辑处理、跳转、异常等都需要其协作完成。该区域线程隔离,各个线程之间的计数器互不影响,独立存储,这个区域也被称为“线程私有域”。
参考链接: https://blog.csdn.net/hhb200766/article/details/46912325
2 java虚拟机栈:java方法执行的内存模型
每个方法执行的时候会创建一个栈帧,存储局部变量表、操作数栈、动态链接,方法接口等信息,每个方法从调用到结束就对应着一个栈帧从入栈到出栈的过程。
局部变量表: 存放了编译期可知的各种类型,对象引用,返回地址值
3 本地方法栈
与虚拟机栈发挥的作用非常相似,区别是一个为虚拟机执行的java提供服务,一个位本地方法native服务。
Sun HotSport 虚拟机将二者合并为一个栈。
4 java 堆:java虚拟机管理的内存中最大的一块区域,gc的主要区域
JIT编译器
逃逸分析
栈分配和标量替换
5 方法区 各个线程共享的区域
用于存储已经被虚拟机加载的类信息,常量,静态变量,即时编译器后的代码数据。
虚拟机把方法区描述为堆中的一个逻辑部分;
6 运行时常量池
属于方法区的一部分,必然受方法区内存的限制,超出则抛出OutOfMemoryError异常。
直接内存:
NIO:基于通道和缓冲区的I/O方式,可以使用native函数直接分配堆外内存,显著提升了性能,不受jvm内存限制,但受到本机总内存的限制,超出同样会抛出OutOfMemoryError异常。