jvm内存划分概览

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异常。

你可能感兴趣的:(jvm内存划分概览)