JVM 内存模型,分为哪些区域?各区域的作用是什么?

JVM 内存模型分为以下几个区域:

1.程序计数器(ProgramCounterRegister):每个线程都有自己的程序计数器,用于指示当前线程执行的字节码指令的行号,以便线程执行时能够回到正确的位置。

  1. 虚拟机栈(JVMStack):也称为Java方法栈,用于存储方法执行时的局部变量表、操作数栈、动态链接、方 法出口等信息。每个线程在执行一个方法时,都会为该方法分配一个栈帧,并将该栈帧压入虚拟机栈,当方法 执行完毕后,虚拟机会将其出栈。

  2. 本地方法栈(NativeMethodStack):与虚拟机栈类似,用于存储本地方法的执行信息。

  3. 堆(Heap):用于存储对象实例,是JVM中最大的一块内存区域。堆是被所有线程共享的,当创建一个新对 象时,对象实例存储在堆中,堆中存储的对象实例都有一个标记用于标记对象是否存活。垃圾回收器会周期性 地回收那些没有被标记为存活的对象。

  4. 方法区(MethodArea):用于存储已经被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代 码等数据。方法区也是被所有线程共享的。

  5. 运行时常量池(RuntimeConstantPool):是方法区的一部分,用于存储编译期间生成的各种字面量和符号 引用,这些内容在类加载后进入常量池中。

其中,程序计数器、虚拟机栈、本地方法栈是线程私有的,堆、方法区、运行时常量池是线程共享的。

相关推荐
SL_staff25 分钟前
3周搭完MES系统:JVS低代码+JVS-IoT物联网的实战记录
java·前端·低代码
MacroZheng32 分钟前
斩获20w star!Claude Code最强插件,AI编程必备!
java·人工智能·后端
唐青枫2 小时前
Java Spring WebFlux 实战指南:用 Mono、Flux 和 WebClient 写响应式接口
java·spring
小bo波15 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking16 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
LiuMingXin17 小时前
意图与代码之间:AI编程范式全景解读
前端·后端·面试
以和为贵18 小时前
前端也能搞懂 RAG:用 JS 手写一条最小检索增强链路
前端·人工智能·面试
张不才19 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
shepherd11120 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
半个落月1 天前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试