jvm内存区域划分 Java8
时间: 2023-11-12 13:07:18 浏览: 129
Java8 中,JVM 内存区域主要划分为以下几个部分:
1. 程序计数器(Program Counter Register):记录当前线程执行的字节码地址,是线程私有的内存区域。
2. Java 虚拟机栈(Java Virtual Machine Stacks):每个方法在执行的同时都会创建一个栈帧用于存储局部变量表、操作数栈、动态链接、方法出口等信息,是线程私有的内存区域。
3. 本地方法栈(Native Method Stack):与 Java 虚拟机栈类似,但是为本地方法服务,也是线程私有的内存区域。
4. Java 堆(Java Heap):存放对象实例,是所有线程共享的内存区域。
5. 方法区(Method Area):存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据,也是所有线程共享的内存区域。
6. 直接内存(Direct Memory):和 Java 堆一样,也是堆外内存,但是它不受 Java 堆大小限制。JDK1.4 引入 NIO 类型,引入了一种基于通道与缓冲区的 I/O 方式,可以使用 Native 函数库直接分配堆外内存,然后通过一个存储在 Java 堆中的 DirectByteBuffer 对象作为这块内存的引用操作这块内存。可以提高性能,但是也增加了内存管理的复杂度。
阅读全文